2013-02-01 19:40:47 +08:00
|
|
|
; RUN: llc -mtriple=aarch64-none-linux-gnu -verify-machineinstrs -filetype=obj < %s | elf-dump | FileCheck %s
|
2013-01-31 20:12:40 +08:00
|
|
|
|
2013-02-15 17:33:43 +08:00
|
|
|
define i64 @testfn() nounwind {
|
2013-01-31 20:12:40 +08:00
|
|
|
entry:
|
2013-02-15 17:33:43 +08:00
|
|
|
ret i64 0
|
2013-01-31 20:12:40 +08:00
|
|
|
}
|
|
|
|
|
2013-02-15 17:33:43 +08:00
|
|
|
define i64 @foo() nounwind {
|
2013-01-31 20:12:40 +08:00
|
|
|
entry:
|
2013-02-15 17:33:43 +08:00
|
|
|
%bar = alloca i64 ()*, align 8
|
|
|
|
store i64 ()* @testfn, i64 ()** %bar, align 8
|
|
|
|
%call = call i64 @testfn()
|
|
|
|
ret i64 %call
|
2013-01-31 20:12:40 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
; The above should produce an ADRP/ADD pair to calculate the address of
|
|
|
|
; testfn. The important point is that LLVM shouldn't think it can deal with the
|
|
|
|
; relocation on the ADRP itself (even though it knows everything about the
|
|
|
|
; relative offsets of testfn and foo) because its value depends on where this
|
|
|
|
; object file's .text section gets relocated in memory.
|
|
|
|
|
|
|
|
; CHECK: .rela.text
|
|
|
|
|
|
|
|
; CHECK: # Relocation 0
|
2013-02-15 17:33:43 +08:00
|
|
|
; CHECK-NEXT: (('r_offset', 0x0000000000000010)
|
|
|
|
; CHECK-NEXT: ('r_sym', 0x00000007)
|
2013-01-31 20:12:40 +08:00
|
|
|
; CHECK-NEXT: ('r_type', 0x00000113)
|
|
|
|
; CHECK-NEXT: ('r_addend', 0x0000000000000000)
|
|
|
|
; CHECK-NEXT: ),
|
|
|
|
; CHECK-NEXT: Relocation 1
|
2013-02-15 17:33:43 +08:00
|
|
|
; CHECK-NEXT: (('r_offset', 0x0000000000000014)
|
|
|
|
; CHECK-NEXT: ('r_sym', 0x00000007)
|
2013-01-31 20:12:40 +08:00
|
|
|
; CHECK-NEXT: ('r_type', 0x00000115)
|
|
|
|
; CHECK-NEXT: ('r_addend', 0x0000000000000000)
|
|
|
|
; CHECK-NEXT: ),
|