mirror of
https://github.com/RPCS3/llvm.git
synced 2024-12-13 14:47:00 +00:00
[safestack] Fix a stupid mix-up in the direct-tls code path.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@248863 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
0ecc14ae7e
commit
129d8a8eb0
@ -254,7 +254,7 @@ Value *SafeStack::getOrCreateUnsafeStackPtr(IRBuilder<> &IRB, Function &F) {
|
||||
unsigned Offset;
|
||||
unsigned AddressSpace;
|
||||
// Check if the target keeps the unsafe stack pointer at a fixed offset.
|
||||
if (TLI && TLI->getSafeStackPointerLocation(Offset, AddressSpace)) {
|
||||
if (TLI && TLI->getSafeStackPointerLocation(AddressSpace, Offset)) {
|
||||
Constant *OffsetVal =
|
||||
ConstantInt::get(Type::getInt32Ty(F.getContext()), Offset);
|
||||
return ConstantExpr::getIntToPtr(OffsetVal,
|
||||
|
32
test/CodeGen/X86/safestack.ll
Normal file
32
test/CodeGen/X86/safestack.ll
Normal file
@ -0,0 +1,32 @@
|
||||
; RUN: llc -mtriple=i386-linux < %s -o - | FileCheck --check-prefix=LINUX-I386 %s
|
||||
; RUN: llc -mtriple=x86_64-linux < %s -o - | FileCheck --check-prefix=LINUX-X64 %s
|
||||
; RUN: llc -mtriple=i386-linux-android < %s -o - | FileCheck --check-prefix=ANDROID-I386 %s
|
||||
; RUN: llc -mtriple=x86_64-linux-android < %s -o - | FileCheck --check-prefix=ANDROID-X64 %s
|
||||
|
||||
define void @_Z1fv() safestack {
|
||||
entry:
|
||||
%x = alloca i32, align 4
|
||||
%0 = bitcast i32* %x to i8*
|
||||
call void @_Z7CapturePi(i32* nonnull %x)
|
||||
ret void
|
||||
}
|
||||
|
||||
declare void @_Z7CapturePi(i32*)
|
||||
|
||||
; LINUX-X64: movq __safestack_unsafe_stack_ptr@GOTTPOFF(%rip), %[[A:.*]]
|
||||
; LINUX-X64: movq %fs:(%[[A]]), %[[B:.*]]
|
||||
; LINUX-X64: leaq -16(%[[B]]), %[[C:.*]]
|
||||
; LINUX-X64: movq %[[C]], %fs:(%[[A]])
|
||||
|
||||
; LINUX-I386: movl __safestack_unsafe_stack_ptr@INDNTPOFF, %[[A:.*]]
|
||||
; LINUX-I386: movl %gs:(%[[A]]), %[[B:.*]]
|
||||
; LINUX-I386: leal -16(%[[B]]), %[[C:.*]]
|
||||
; LINUX-I386: movl %[[C]], %gs:(%[[A]])
|
||||
|
||||
; ANDROID-I386: movl %gs:36, %[[A:.*]]
|
||||
; ANDROID-I386: leal -16(%[[A]]), %[[B:.*]]
|
||||
; ANDROID-I386: movl %[[B]], %gs:36
|
||||
|
||||
; ANDROID-X64: movq %fs:72, %[[A:.*]]
|
||||
; ANDROID-X64: leaq -16(%[[A]]), %[[B:.*]]
|
||||
; ANDROID-X64: movq %[[B]], %fs:72
|
@ -10,20 +10,20 @@ entry:
|
||||
; TLS: %[[USST:.*]] = getelementptr i8, i8* %[[USP]], i32 -16
|
||||
; TLS: store i8* %[[USST]], i8** @__safestack_unsafe_stack_ptr
|
||||
|
||||
; DIRECT-TLS32: %[[USP:.*]] = load i8*, i8* addrspace(36)* inttoptr (i32 256 to i8* addrspace(36)*)
|
||||
; DIRECT-TLS32: %[[USP:.*]] = load i8*, i8* addrspace(256)* inttoptr (i32 36 to i8* addrspace(256)*)
|
||||
; DIRECT-TLS32: %[[USST:.*]] = getelementptr i8, i8* %[[USP]], i32 -16
|
||||
; DIRECT-TLS32: store i8* %[[USST]], i8* addrspace(36)* inttoptr (i32 256 to i8* addrspace(36)*)
|
||||
; DIRECT-TLS32: store i8* %[[USST]], i8* addrspace(256)* inttoptr (i32 36 to i8* addrspace(256)*)
|
||||
|
||||
; DIRECT-TLS64: %[[USP:.*]] = load i8*, i8* addrspace(72)* inttoptr (i32 257 to i8* addrspace(72)*)
|
||||
; DIRECT-TLS64: %[[USP:.*]] = load i8*, i8* addrspace(257)* inttoptr (i32 72 to i8* addrspace(257)*)
|
||||
; DIRECT-TLS64: %[[USST:.*]] = getelementptr i8, i8* %[[USP]], i32 -16
|
||||
; DIRECT-TLS64: store i8* %[[USST]], i8* addrspace(72)* inttoptr (i32 257 to i8* addrspace(72)*)
|
||||
; DIRECT-TLS64: store i8* %[[USST]], i8* addrspace(257)* inttoptr (i32 72 to i8* addrspace(257)*)
|
||||
|
||||
%a = alloca i8, align 8
|
||||
call void @Capture(i8* %a)
|
||||
|
||||
; TLS: store i8* %[[USP]], i8** @__safestack_unsafe_stack_ptr
|
||||
; DIRECT-TLS32: store i8* %[[USP]], i8* addrspace(36)* inttoptr (i32 256 to i8* addrspace(36)*)
|
||||
; DIRECT-TLS64: store i8* %[[USP]], i8* addrspace(72)* inttoptr (i32 257 to i8* addrspace(72)*)
|
||||
; DIRECT-TLS32: store i8* %[[USP]], i8* addrspace(256)* inttoptr (i32 36 to i8* addrspace(256)*)
|
||||
; DIRECT-TLS64: store i8* %[[USP]], i8* addrspace(257)* inttoptr (i32 72 to i8* addrspace(257)*)
|
||||
ret void
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user