diff options
author | Lauro Ramos Venancio <lauro.venancio@gmail.com> | 2007-11-05 18:33:37 +0000 |
---|---|---|
committer | Lauro Ramos Venancio <lauro.venancio@gmail.com> | 2007-11-05 18:33:37 +0000 |
commit | 7eccd2b40188dd1481bae1458d675152447823b9 (patch) | |
tree | 4fed27545b52619ff5e44e2ceb50e1a440c7a1c1 | |
parent | 3041c275ff7fcca22e7114207420d5d61bf03903 (diff) | |
download | external_llvm-7eccd2b40188dd1481bae1458d675152447823b9.zip external_llvm-7eccd2b40188dd1481bae1458d675152447823b9.tar.gz external_llvm-7eccd2b40188dd1481bae1458d675152447823b9.tar.bz2 |
[ARM] Fix code generation for:
static __thread struct {
int a;
int b;
} teste = {0, 0};
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@43722 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Target/ARM/ARMAsmPrinter.cpp | 2 | ||||
-rw-r--r-- | test/CodeGen/ARM/tls3.ll | 11 |
2 files changed, 12 insertions, 1 deletions
diff --git a/lib/Target/ARM/ARMAsmPrinter.cpp b/lib/Target/ARM/ARMAsmPrinter.cpp index 924a2df..5f46b07 100644 --- a/lib/Target/ARM/ARMAsmPrinter.cpp +++ b/lib/Target/ARM/ARMAsmPrinter.cpp @@ -836,7 +836,7 @@ bool ARMAsmPrinter::doFinalization(Module &M) { if (Subtarget->isTargetELF()) O << "\t.type " << name << ",%object\n"; - if (C->isNullValue() && !I->hasSection()) { + if (C->isNullValue() && !I->hasSection() && !I->isThreadLocal()) { if (I->hasExternalLinkage()) { if (const char *Directive = TAI->getZeroFillDirective()) { O << "\t.globl\t" << name << "\n"; diff --git a/test/CodeGen/ARM/tls3.ll b/test/CodeGen/ARM/tls3.ll new file mode 100644 index 0000000..df2913b --- /dev/null +++ b/test/CodeGen/ARM/tls3.ll @@ -0,0 +1,11 @@ +; RUN: llvm-as < %s | llc -march=arm -mtriple=arm-linux-gnueabi | \ +; RUN: grep {tbss} + +%struct.anon = type { i32, i32 } +@teste = internal thread_local global %struct.anon zeroinitializer ; <%struct.anon*> [#uses=1] + +define i32 @main() { +entry: + %tmp2 = load i32* getelementptr (%struct.anon* @teste, i32 0, i32 0), align 8 ; <i32> [#uses=1] + ret i32 %tmp2 +} |