2017-08-16 04:29:24 +08:00
|
|
|
# RUN: rm -rf %t && mkdir -p %t
|
|
|
|
# RUN: llvm-mc -triple=arm64-apple-ios7.0.0 -filetype=obj -o %t/foo.o %s
|
|
|
|
# RUN: llvm-rtdyld -triple=arm64-apple-ios7.0.0 -map-section foo.o,__text=0x10bc0 -verify -check=%s %t/foo.o
|
2014-07-23 05:42:55 +08:00
|
|
|
|
|
|
|
.section __TEXT,__text,regular,pure_instructions
|
|
|
|
.ios_version_min 7, 0
|
2014-07-24 06:23:17 +08:00
|
|
|
.globl _foo
|
2014-07-23 05:42:55 +08:00
|
|
|
.align 2
|
2014-07-24 06:23:17 +08:00
|
|
|
_foo:
|
2014-07-23 05:42:55 +08:00
|
|
|
movz w0, #0
|
|
|
|
ret
|
|
|
|
|
|
|
|
.globl _test_branch_reloc
|
|
|
|
.align 2
|
|
|
|
|
|
|
|
|
|
|
|
# Test ARM64_RELOC_BRANCH26 relocation. The branch instruction only encodes 26
|
|
|
|
# bits of the 28-bit possible branch range. The lower two bits are always zero
|
|
|
|
# and therefore ignored.
|
2014-07-24 06:23:17 +08:00
|
|
|
# rtdyld-check: decode_operand(br1, 0)[25:0] = (_foo - br1)[27:2]
|
2014-07-23 05:42:55 +08:00
|
|
|
_test_branch_reloc:
|
|
|
|
br1:
|
2014-07-24 06:23:17 +08:00
|
|
|
b _foo
|
2014-07-23 05:42:55 +08:00
|
|
|
ret
|
|
|
|
|
|
|
|
|
|
|
|
# Test ARM64_RELOC_PAGE21 and ARM64_RELOC_PAGEOFF12 relocation. adrp encodes
|
|
|
|
# the PC-relative page (4 KiB) difference between the adrp instruction and the
|
|
|
|
# variable ptr. ldr encodes the offset of the variable within the page. The ldr
|
|
|
|
# instruction perfroms an implicit shift on the encoded immediate (imm<<3).
|
2014-07-24 06:23:17 +08:00
|
|
|
# rtdyld-check: decode_operand(adrp1, 1) = (_ptr[32:12] - adrp1[32:12])
|
2014-07-29 05:00:48 +08:00
|
|
|
# rtdyld-check: decode_operand(ldr1, 2) = _ptr[11:3]
|
2014-07-23 05:42:55 +08:00
|
|
|
.globl _test_adrp_ldr
|
|
|
|
.align 2
|
|
|
|
_test_adrp_ldr:
|
|
|
|
adrp1:
|
2014-07-24 06:23:17 +08:00
|
|
|
adrp x0, _ptr@PAGE
|
2014-07-23 05:42:55 +08:00
|
|
|
ldr1:
|
2014-07-24 06:23:17 +08:00
|
|
|
ldr x0, [x0, _ptr@PAGEOFF]
|
|
|
|
ret
|
|
|
|
|
|
|
|
# Test ARM64_RELOC_GOT_LOAD_PAGE21 and ARM64_RELOC_GOT_LOAD_PAGEOFF12
|
|
|
|
# relocation. adrp encodes the PC-relative page (4 KiB) difference between the
|
|
|
|
# adrp instruction and the GOT entry for ptr. ldr encodes the offset of the GOT
|
|
|
|
# entry within the page. The ldr instruction perfroms an implicit shift on the
|
|
|
|
# encoded immediate (imm<<3).
|
2014-07-30 04:40:37 +08:00
|
|
|
# rtdyld-check: *{8}(stub_addr(foo.o, __text, _ptr)) = _ptr
|
|
|
|
# rtdyld-check: decode_operand(adrp2, 1) = (stub_addr(foo.o, __text, _ptr)[32:12] - adrp2[32:12])
|
|
|
|
# rtdyld-check: decode_operand(ldr2, 2) = stub_addr(foo.o, __text, _ptr)[11:3]
|
2014-07-24 06:23:17 +08:00
|
|
|
.globl _test_adrp_ldr
|
|
|
|
.align 2
|
|
|
|
_test_got_adrp_ldr:
|
|
|
|
adrp2:
|
|
|
|
adrp x0, _ptr@GOTPAGE
|
|
|
|
ldr2:
|
|
|
|
ldr x0, [x0, _ptr@GOTPAGEOFF]
|
2014-07-23 05:42:55 +08:00
|
|
|
ret
|
2014-07-24 06:23:17 +08:00
|
|
|
|
2015-08-11 14:27:53 +08:00
|
|
|
# rtdyld-check: decode_operand(add1, 2) = (tgt+8)[11:2] << 2
|
|
|
|
.globl _test_explicit_addend_reloc
|
|
|
|
.align 4
|
|
|
|
_test_explicit_addend_reloc:
|
|
|
|
add1:
|
|
|
|
add x0, x0, tgt@PAGEOFF+8
|
|
|
|
|
|
|
|
.align 3
|
|
|
|
tgt:
|
|
|
|
.long 0
|
|
|
|
.long 0
|
|
|
|
.long 7
|
2014-07-24 06:23:17 +08:00
|
|
|
|
|
|
|
# Test ARM64_RELOC_UNSIGNED relocation. The absolute 64-bit address of the
|
|
|
|
# function should be stored at the 8-byte memory location.
|
|
|
|
# rtdyld-check: *{8}_ptr = _foo
|
|
|
|
.section __DATA,__data
|
|
|
|
.globl _ptr
|
|
|
|
.align 3
|
|
|
|
.fill 4096, 1, 0
|
|
|
|
_ptr:
|
|
|
|
.quad _foo
|
2016-01-22 05:59:50 +08:00
|
|
|
|
|
|
|
# Test ARM64_RELOC_SUBTRACTOR.
|
|
|
|
# rtdyld-check: *{8}_subtractor_result = _test_branch_reloc - _foo
|
|
|
|
_subtractor_result:
|
|
|
|
.quad _test_branch_reloc - _foo
|