diff options
author | Anton Korobeynikov <anton@korobeynikov.info> | 2019-02-12 20:46:00 +0000 |
---|---|---|
committer | Anton Korobeynikov <anton@korobeynikov.info> | 2019-02-12 20:46:00 +0000 |
commit | a39eb26bd3f1e9fb5eacc755a8a31f4081682f0e (patch) | |
tree | 49b18d36041b2d50b6cb8620fb739d85242ca90c | |
parent | 08c3841b21cf58cefebdac24e54f40c7ed4b6080 (diff) | |
download | bcm5719-llvm-a39eb26bd3f1e9fb5eacc755a8a31f4081682f0e.tar.gz bcm5719-llvm-a39eb26bd3f1e9fb5eacc755a8a31f4081682f0e.zip |
Disable PIC/PIE for MSP430 target
Relocatable code generation is meaningless on MSP430, as the platform is too small to use shared libraries.
Patch by Dmitry Mikushev!
Differential Revision: https://reviews.llvm.org/D56927
llvm-svn: 353877
-rw-r--r-- | clang/lib/Driver/ToolChains/MSP430.h | 4 | ||||
-rw-r--r-- | clang/test/CodeGen/msp430-reloc.c | 30 |
2 files changed, 34 insertions, 0 deletions
diff --git a/clang/lib/Driver/ToolChains/MSP430.h b/clang/lib/Driver/ToolChains/MSP430.h index 61fd0e1455b..b5308a8dd68 100644 --- a/clang/lib/Driver/ToolChains/MSP430.h +++ b/clang/lib/Driver/ToolChains/MSP430.h @@ -36,6 +36,10 @@ public: llvm::opt::ArgStringList &CC1Args, Action::OffloadKind) const override; + bool isPICDefault() const override { return false; } + bool isPIEDefault() const override { return false; } + bool isPICDefaultForced() const override { return true; } + protected: Tool *buildLinker() const override; diff --git a/clang/test/CodeGen/msp430-reloc.c b/clang/test/CodeGen/msp430-reloc.c new file mode 100644 index 00000000000..f3d858839ec --- /dev/null +++ b/clang/test/CodeGen/msp430-reloc.c @@ -0,0 +1,30 @@ +// REQUIRES: msp430-registered-target +// RUN: %clang -target msp430 -fPIC -S %s -o - | FileCheck %s + +// Check the compilation does not crash as it was crashing before with "-fPIC" enabled + +void *alloca(unsigned int size); + +// CHECK: .globl foo +short foo(char** data, char encoding) +{ + char* encoding_addr = alloca(sizeof(char)); + *encoding_addr = encoding; + + char tmp3 = *encoding_addr; + short conv2 = tmp3; + short and = conv2 & 0xf; + + switch (and) + { + case 0 : + case 4 : + case 10 : + return 1; + case 11 : + return 2; + } + + return 0; +} + |