mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-13 20:32:21 +00:00
[X86] Don't try to generate direct calls to TLS globals
The call lowering assumes that if the callee is a global, we want to emit a direct call. This is correct for regular globals, but not for TLS ones. Differential Revision: http://reviews.llvm.org/D6862 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@225438 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
1cea749780
commit
0858c28ca8
@ -3083,10 +3083,11 @@ X86TargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
||||
// through a register, since the call instruction's 32-bit
|
||||
// pc-relative offset may not be large enough to hold the whole
|
||||
// address.
|
||||
} else if (GlobalAddressSDNode *G = dyn_cast<GlobalAddressSDNode>(Callee)) {
|
||||
} else if (Callee->getOpcode() == ISD::GlobalAddress) {
|
||||
// If the callee is a GlobalAddress node (quite common, every direct call
|
||||
// is) turn it into a TargetGlobalAddress node so that legalize doesn't hack
|
||||
// it.
|
||||
GlobalAddressSDNode* G = cast<GlobalAddressSDNode>(Callee);
|
||||
|
||||
// We should use extra load for direct calls to dllimported functions in
|
||||
// non-JIT mode.
|
||||
|
19
test/CodeGen/X86/pr22103.ll
Normal file
19
test/CodeGen/X86/pr22103.ll
Normal file
@ -0,0 +1,19 @@
|
||||
; RUN: llc < %s | FileCheck %s
|
||||
; Don't try to emit a direct call through a TLS global.
|
||||
; This fixes PR22103
|
||||
|
||||
target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
|
||||
target triple = "x86_64-unknown-linux-gnu"
|
||||
|
||||
@a = external thread_local global i64
|
||||
|
||||
; Function Attrs: nounwind
|
||||
define void @_Z1fv() {
|
||||
; CHECK-NOT: callq *$a
|
||||
; CHECK: movq %fs:0, [[RAX:%r..]]
|
||||
; CHECK-NEXT: addq a@GOTTPOFF(%rip), [[RAX]]
|
||||
; CHECK-NEXT: callq *%rax
|
||||
entry:
|
||||
call void bitcast (i64* @a to void ()*)()
|
||||
ret void
|
||||
}
|
Loading…
Reference in New Issue
Block a user