| // RUN: not llvm-mc -triple aarch64--none-eabi -filetype obj < %s -o /dev/null 2>&1 | FileCheck %s |
| |
| // Note: These errors are not always emitted in the order in which the relevant |
| // source appears, this file is carefully ordered so that that is the case. |
| |
| .text |
| // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: symbol 'undef' can not be undefined in a subtraction expression |
| .word (0-undef) |
| |
| // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: expected relocatable expression |
| .word -undef |
| |
| // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: No relocation available to represent this relative expression |
| adr x0, #a-undef |
| |
| // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: Cannot represent a difference across sections |
| .word x_a - y_a |
| |
| // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: 1-byte data relocations not supported |
| .byte undef |
| |
| // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: 1-byte data relocations not supported |
| .byte undef-. |
| |
| // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: Unsupported pc-relative fixup kind |
| ldr x0, [x1, :lo12:undef-.] |
| |
| // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: invalid fixup for 8-bit load/store instruction |
| ldrb w0, [x1, :gottprel_lo12:undef] |
| |
| // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: invalid fixup for 16-bit load/store instruction |
| ldrh w0, [x1, :gottprel_lo12:undef] |
| |
| // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: invalid fixup for 32-bit load/store instruction |
| ldr w0, [x1, :gottprel_lo12:undef] |
| |
| // CHECK: <unknown>:0: error: expression could not be evaluated |
| .set v1, -undef |
| |
| .comm common, 4 |
| // CHECK: <unknown>:0: error: Common symbol 'common' cannot be used in assignment expr |
| .set v3, common |
| |
| // CHECK: <unknown>:0: error: symbol 'undef' could not be evaluated in a subtraction expression |
| .set v2, a-undef |
| |
| |
| |
| w: |
| .word 0 |
| .weak w |
| |
| |
| .section sec_x |
| x_a: |
| .word 0 |
| |
| |
| .section sec_y |
| y_a: |
| .word 0 |