mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-08-09 11:25:55 +00:00
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
20 lines
516 B
LLVM
20 lines
516 B
LLVM
; 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
|
|
}
|