arm-thumb-adr-err.s
983 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
// REQUIRES: arm
// RUN: llvm-mc --triple=thumbv6m-none-eabi --arm-add-build-attributes -filetype=obj -o %t.o %s
// RUN: not ld.lld %t.o -o /dev/null 2>&1 | FileCheck %s
.section .text.0, "ax", %progbits
.balign 4
.thumb_func
low:
bx lr
.section .text.1, "ax", %progbits
.balign 2
.global _start
.thumb_func
_start:
// CHECK: {{.*}}.s.tmp.o:(.text.1+0x0): relocation R_ARM_THM_PC8 out of range: 18446744073709551612 is not in [0, 1023]
/// adr r0, low
.inst.n 0xa0ff
.reloc 0, R_ARM_THM_PC8, low
// CHECK: {{.*}}.s.tmp.o:(.text.1+0x2): improper alignment for relocation R_ARM_THM_PC8: 0x2 is not aligned to 4 bytes
/// adr r1, unaligned
.inst.n 0xa1ff
.reloc 2, R_ARM_THM_PC8, unaligned
// CHECK: {{.*}}.s.tmp.o:(.text.1+0x4): relocation R_ARM_THM_PC8 out of range: 1024 is not in [0, 1023]
/// adr r2, range
.inst.n 0xa2ff
.reloc 4, R_ARM_THM_PC8, range
.section .text.2, "ax", %progbits
.balign 4
nop
.thumb_func
unaligned:
bx lr
.space 1020
range:
bx lr