[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / llvm / test / MC / AArch64 / fixup-out-of-range.s
blob7f4b1e90dad017c2a86e411a66e9f24404ccdb87
1 // RUN: not llvm-mc -triple aarch64 -filetype obj < %s -o /dev/null 2>&1 | FileCheck %s
2 // RUN: not llvm-mc -triple aarch64-windows -filetype obj < %s -o /dev/null 2>&1 | FileCheck %s -check-prefixes=CHECK,CHECK-WIN
4 // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: fixup value out of range
5 adr x0, distant
7 // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: fixup value out of range
8 ldr x0, distant
10 // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: fixup not sufficiently aligned
11 ldr x0, unaligned
13 // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: fixup value out of range
14 b.eq distant
16 // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: fixup not sufficiently aligned
17 b.eq unaligned
19 // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: fixup value out of range
20 ldr x0, [x1, distant-.]
22 // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: fixup must be 8-byte aligned
23 ldr x0, [x1, unaligned-.]
25 // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: fixup value out of range
26 ldr w0, [x1, distant-.]
28 // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: fixup must be 4-byte aligned
29 ldr w0, [x1, unaligned-.]
31 // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: fixup value out of range
32 ldrh w0, [x1, distant-.]
34 // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: fixup must be 2-byte aligned
35 ldrh w0, [x1, unaligned-.]
37 // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: fixup value out of range
38 ldrb w0, [x1, distant-.]
40 // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: fixup value out of range
41 ldr q0, [x1, distant-.]
43 // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: fixup must be 16-byte aligned
44 ldr q0, [x1, unaligned-.]
46 // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: fixup value out of range
47 tbz x0, #1, distant
49 // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: fixup not sufficiently aligned
50 tbz x0, #1, unaligned
52 // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: fixup value out of range
53 b distant
55 // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: fixup not sufficiently aligned
56 b unaligned
58 // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: fixup value out of range
59 movz x0, #:abs_g0:value1
61 // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: fixup value out of range
62 movz x0, #:abs_g1:value2
64 // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: fixup value out of range
65 movz x0, #:abs_g0_s:value1
67 // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: fixup value out of range
68 movz x0, #:abs_g1_s:value2
70 // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: relocation for a thread-local variable points to an absolute symbol
71 movz x0, #:tprel_g0:value1
73 // CHECK-WIN: :[[@LINE+1]]:{{[0-9]+}}: error: fixup value out of range
74 adrp x0, external+0x1000000
76 .byte 0
77 unaligned:
78 .byte 0
80 .space 1<<27
81 .balign 8
82 distant:
83 .word 0
84 value1 = 0x12345678
85 value2 = 0x123456789