mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-15 23:31:37 +00:00
58fc1f52ce
The PowerPC-specific modifiers VK_PPC_TLSGD and VK_PPC_TLSLD correspond exactly to the generic modifiers VK_TLSGD and VK_TLSLD. This causes some confusion with the asm parser, since VK_PPC_TLSGD is output as @tlsgd, which is then read back in as VK_TLSGD. To avoid this confusion, this patch removes the PowerPC-specific modifiers and uses the generic modifiers throughout. (The only drawback is that the generic modifiers are printed in upper case while the usual convention on PowerPC is to use lower-case modifiers. But this is just a cosmetic issue.) git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@185476 91177308-0d34-0410-b5e6-96231b3b80d8
25 lines
807 B
LLVM
25 lines
807 B
LLVM
; RUN: llc -mcpu=pwr7 -O0 -relocation-model=pic < %s | FileCheck %s
|
|
|
|
; Test correct assembly code generation for thread-local storage using
|
|
; the local dynamic model.
|
|
|
|
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-f128:128:128-v128:128:128-n32:64"
|
|
target triple = "powerpc64-unknown-linux-gnu"
|
|
|
|
@a = hidden thread_local global i32 0, align 4
|
|
|
|
define signext i32 @main() nounwind {
|
|
entry:
|
|
%retval = alloca i32, align 4
|
|
store i32 0, i32* %retval
|
|
%0 = load i32* @a, align 4
|
|
ret i32 %0
|
|
}
|
|
|
|
; CHECK: addis [[REG:[0-9]+]], 2, a@got@tlsld@ha
|
|
; CHECK-NEXT: addi 3, [[REG]], a@got@tlsld@l
|
|
; CHECK: bl __tls_get_addr(a@TLSLD)
|
|
; CHECK-NEXT: nop
|
|
; CHECK: addis [[REG2:[0-9]+]], 3, a@dtprel@ha
|
|
; CHECK-NEXT: addi {{[0-9]+}}, [[REG2]], a@dtprel@l
|