blob: 04fd579695bedce165d97a55fae4a07d153b7027 [file] [log] [blame]
; RUN: llc --relocation-model=static < %s | FileCheck %s
target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
target triple = "x86_64-unknown-linux-gnu"
@global = external dso_local global i32
declare dso_local void @func()
define i32* @global_addr() #0 {
; CHECK-LABEL: global_addr:
; CHECK: movq global@GOTPCREL_NORELAX(%rip), %rax
; CHECK: retq
ret i32* @global
}
define i32 @global_load() #0 {
; CHECK-LABEL: global_load:
; CHECK: movq global@GOTPCREL_NORELAX(%rip), [[REG:%r[0-9a-z]+]]
; CHECK: movl ([[REG]]), %eax
; CHECK: retq
%load = load i32, i32* @global
ret i32 %load
}
define void @global_store() #0 {
; CHECK-LABEL: global_store:
; CHECK: movq global@GOTPCREL_NORELAX(%rip), [[REG:%r[0-9a-z]+]]
; CHECK: movl $0, ([[REG]])
; CHECK: retq
store i32 0, i32* @global
ret void
}
define void ()* @func_addr() #0 {
; CHECK-LABEL: func_addr:
; CHECK: movl $func, %eax
; CHECK: retq
ret void ()* @func
}
; Jump tables shouldn't go through the GOT.
define i32 @jump_table(i32 %x) #0 {
; CHECK-LABEL: jump_table:
; CHECK-NOT: @GOT
switch i32 %x, label %default [
i32 0, label %1
i32 1, label %2
i32 2, label %3
i32 3, label %4
]
1:
ret i32 7
2:
ret i32 42
3:
ret i32 3
4:
ret i32 8
default:
ret i32 %x
}
attributes #0 = { "target-features"="+tagged-globals" }