Define Contiki OS toolchain

Patch by Michael LeMay

Differential revision: http://reviews.llvm.org/D19854

llvm-svn: 284278
This commit is contained in:
David L Kreitzer 2016-10-14 20:44:33 +00:00
parent c37a49896a
commit d397ea4d6f
4 changed files with 23 additions and 0 deletions

View File

@ -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.

View File

@ -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;
}

View File

@ -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

View File

@ -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"