forked from OSchip/llvm-project
Define Contiki OS toolchain
Patch by Michael LeMay Differential revision: http://reviews.llvm.org/D19854 llvm-svn: 284278
This commit is contained in:
parent
c37a49896a
commit
d397ea4d6f
|
@ -3120,6 +3120,9 @@ const ToolChain &Driver::getToolChain(const ArgList &Args,
|
|||
case llvm::Triple::PS4:
|
||||
TC = new toolchains::PS4CPU(*this, Target, Args);
|
||||
break;
|
||||
case llvm::Triple::Contiki:
|
||||
TC = new toolchains::Contiki(*this, Target, Args);
|
||||
break;
|
||||
default:
|
||||
// Of these targets, Hexagon is the only one that might have
|
||||
// an OS of Linux, in which case it got handled above already.
|
||||
|
|
|
@ -5305,3 +5305,14 @@ SanitizerMask PS4CPU::getSupportedSanitizers() const {
|
|||
Res |= SanitizerKind::Vptr;
|
||||
return Res;
|
||||
}
|
||||
|
||||
Contiki::Contiki(const Driver &D, const llvm::Triple &Triple, const ArgList &Args)
|
||||
: Generic_ELF(D, Triple, Args) {}
|
||||
|
||||
SanitizerMask Contiki::getSupportedSanitizers() const {
|
||||
const bool IsX86 = getTriple().getArch() == llvm::Triple::x86;
|
||||
SanitizerMask Res = ToolChain::getSupportedSanitizers();
|
||||
if (IsX86)
|
||||
Res |= SanitizerKind::SafeStack;
|
||||
return Res;
|
||||
}
|
||||
|
|
|
@ -1249,6 +1249,14 @@ protected:
|
|||
Tool *buildLinker() const override;
|
||||
};
|
||||
|
||||
class LLVM_LIBRARY_VISIBILITY Contiki : public Generic_ELF {
|
||||
public:
|
||||
Contiki(const Driver &D, const llvm::Triple &Triple,
|
||||
const llvm::opt::ArgList &Args);
|
||||
|
||||
SanitizerMask getSupportedSanitizers() const override;
|
||||
};
|
||||
|
||||
} // end namespace toolchains
|
||||
} // end namespace driver
|
||||
} // end namespace clang
|
||||
|
|
|
@ -397,6 +397,7 @@
|
|||
// RUN: %clang -target x86_64-linux-gnu -fsanitize=safe-stack -fstack-protector-all -### %s 2>&1 | FileCheck %s -check-prefix=SP
|
||||
// RUN: %clang -target arm-linux-androideabi -fsanitize=safe-stack -### %s 2>&1 | FileCheck %s -check-prefix=NO-SP
|
||||
// RUN: %clang -target aarch64-linux-android -fsanitize=safe-stack -### %s 2>&1 | FileCheck %s -check-prefix=NO-SP
|
||||
// RUN: %clang -target i386-contiki-unknown -fsanitize=safe-stack -### %s 2>&1 | FileCheck %s -check-prefix=NO-SP
|
||||
// NO-SP-NOT: stack-protector
|
||||
// NO-SP: "-fsanitize=safe-stack"
|
||||
// SP: "-fsanitize=safe-stack"
|
||||
|
|
Loading…
Reference in New Issue