diff options
author | Roman Divacky <rdivacky@freebsd.org> | 2012-06-04 17:36:38 +0000 |
---|---|---|
committer | Roman Divacky <rdivacky@freebsd.org> | 2012-06-04 17:36:38 +0000 |
commit | e3f15c98d1c7de344268ca43e3fb3e54bec686a8 (patch) | |
tree | 166023173d5e476ffc52d02dd79670593c3d9930 /llvm/test/CodeGen/PowerPC/tls.ll | |
parent | 4214f605f731e109b9dec3fcd889ee7eb31a9d53 (diff) | |
download | bcm5719-llvm-e3f15c98d1c7de344268ca43e3fb3e54bec686a8.tar.gz bcm5719-llvm-e3f15c98d1c7de344268ca43e3fb3e54bec686a8.zip |
Implement local-exec TLS on PowerPC.
llvm-svn: 157935
Diffstat (limited to 'llvm/test/CodeGen/PowerPC/tls.ll')
-rw-r--r-- | llvm/test/CodeGen/PowerPC/tls.ll | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/llvm/test/CodeGen/PowerPC/tls.ll b/llvm/test/CodeGen/PowerPC/tls.ll new file mode 100644 index 00000000000..713893bf586 --- /dev/null +++ b/llvm/test/CodeGen/PowerPC/tls.ll @@ -0,0 +1,16 @@ +target datalayout = "E-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v128:128:128-n32:64" +target triple = "powerpc64-unknown-freebsd10.0" +; RUN: llc < %s -march=ppc64 | FileCheck %s + +@a = thread_local global i32 0, align 4 + +;CHECK: localexec: +define i32 @localexec() nounwind { +entry: +;CHECK: addis [[REG1:[0-9]+]], 13, a@tprel@ha +;CHECK-NEXT: li [[REG2:[0-9]+]], 42 +;CHECK-NEXT: addi [[REG1]], [[REG1]], a@tprel@l +;CHECK-NEXT: stw [[REG2]], 0([[REG1]]) + store i32 42, i32* @a, align 4 + ret i32 0 +} |