73 lines
2.1 KiB
LLVM
73 lines
2.1 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
|
|
; RUN: llc -mtriple=x86_64 -relocation-model=static < %s | \
|
|
; RUN: FileCheck --check-prefixes=COMMON,STATIC %s
|
|
; RUN: llc -mtriple=x86_64 -relocation-model=pic < %s | \
|
|
; RUN: FileCheck --check-prefixes=COMMON,CHECK %s
|
|
|
|
;; Test that we use the local alias for dso_local functions in inline assembly.
|
|
|
|
@gv0 = dso_local global i32 0
|
|
@gv1 = dso_preemptable global i32 1
|
|
|
|
define i64 @test_var() nounwind {
|
|
; STATIC-LABEL: test_var:
|
|
; STATIC: # %bb.0: # %entry
|
|
; STATIC-NEXT: movq gv1@GOTPCREL(%rip), %rax
|
|
; STATIC-NEXT: #APP
|
|
; STATIC-NEXT: movq gv0(%rip), %rax
|
|
; STATIC-NEXT: movq (%rax), %rax
|
|
; STATIC-NEXT: #NO_APP
|
|
; STATIC-NEXT: retq
|
|
;
|
|
; CHECK-LABEL: test_var:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: movq gv1@GOTPCREL(%rip), %rax
|
|
; CHECK-NEXT: #APP
|
|
; CHECK-NEXT: movq .Lgv0$local(%rip), %rax
|
|
; CHECK-NEXT: movq (%rax), %rax
|
|
; CHECK-NEXT: #NO_APP
|
|
; CHECK-NEXT: retq
|
|
entry:
|
|
%0 = tail call i64 asm "movq $1, $0\0Amovq $2, $0", "=r,*m,*m"(ptr elementtype(i32) @gv0, ptr elementtype(i32) @gv1)
|
|
ret i64 %0
|
|
}
|
|
|
|
define dso_local void @fun0() nounwind {
|
|
; COMMON-LABEL: fun0:
|
|
; COMMON: # %bb.0: # %entry
|
|
; COMMON-NEXT: retq
|
|
entry:
|
|
ret void
|
|
}
|
|
|
|
define dso_preemptable void @fun1() nounwind {
|
|
; COMMON-LABEL: fun1:
|
|
; COMMON: # %bb.0: # %entry
|
|
; COMMON-NEXT: retq
|
|
entry:
|
|
ret void
|
|
}
|
|
|
|
define i64 @test_fun() nounwind {
|
|
; STATIC-LABEL: test_fun:
|
|
; STATIC: # %bb.0: # %entry
|
|
; STATIC-NEXT: movq fun1@GOTPCREL(%rip), %rax
|
|
; STATIC-NEXT: #APP
|
|
; STATIC-NEXT: movq fun0(%rip), %rax
|
|
; STATIC-NEXT: movq (%rax), %rax
|
|
; STATIC-NEXT: #NO_APP
|
|
; STATIC-NEXT: retq
|
|
;
|
|
; CHECK-LABEL: test_fun:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: movq fun1@GOTPCREL(%rip), %rax
|
|
; CHECK-NEXT: #APP
|
|
; CHECK-NEXT: movq .Lfun0$local(%rip), %rax
|
|
; CHECK-NEXT: movq (%rax), %rax
|
|
; CHECK-NEXT: #NO_APP
|
|
; CHECK-NEXT: retq
|
|
entry:
|
|
%0 = tail call i64 asm "movq $1, $0\0Amovq $2, $0", "=r,*m,*m"(ptr elementtype(void ()) nonnull @fun0, ptr elementtype(void ()) nonnull @fun1)
|
|
ret i64 %0
|
|
}
|