xref: /aosp_15_r20/external/llvm/test/MC/AArch64/arm64-adr.s (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker// RUN: not llvm-mc -triple arm64 -show-encoding < %s 2>%t | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker// RUN: FileCheck --check-prefix=CHECK-ERRORS < %t %s
3*9880d681SAndroid Build Coastguard Worker
4*9880d681SAndroid Build Coastguard Workeradr x0, #0
5*9880d681SAndroid Build Coastguard Workeradr x0, #1
6*9880d681SAndroid Build Coastguard Workeradr x0, 1f
7*9880d681SAndroid Build Coastguard Workeradr x0, foo
8*9880d681SAndroid Build Coastguard Worker// CHECK: adr x0, #0          // encoding: [0x00,0x00,0x00,0x10]
9*9880d681SAndroid Build Coastguard Worker// CHECK: adr x0, #1          // encoding: [0x00,0x00,0x00,0x30]
10*9880d681SAndroid Build Coastguard Worker// CHECK: adr x0, .Ltmp0      // encoding: [A,A,A,0x10'A']
11*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:                //   fixup A - offset: 0, value: .Ltmp0, kind: fixup_aarch64_pcrel_adr_imm21
12*9880d681SAndroid Build Coastguard Worker// CHECK: adr x0, foo         // encoding: [A,A,A,0x10'A']
13*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:                //   fixup A - offset: 0, value: foo, kind: fixup_aarch64_pcrel_adr_imm21
14*9880d681SAndroid Build Coastguard Worker
15*9880d681SAndroid Build Coastguard Workeradrp x0, #0
16*9880d681SAndroid Build Coastguard Workeradrp x0, #4096
17*9880d681SAndroid Build Coastguard Workeradrp x0, 1f
18*9880d681SAndroid Build Coastguard Workeradrp x0, foo
19*9880d681SAndroid Build Coastguard Worker// CHECK: adrp    x0, #0      // encoding: [0x00,0x00,0x00,0x90]
20*9880d681SAndroid Build Coastguard Worker// CHECK: adrp    x0, #4096   // encoding: [0x00,0x00,0x00,0xb0]
21*9880d681SAndroid Build Coastguard Worker// CHECK: adrp    x0, .Ltmp0  // encoding: [A,A,A,0x90'A']
22*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:                //   fixup A - offset: 0, value: .Ltmp0, kind: fixup_aarch64_pcrel_adrp_imm21
23*9880d681SAndroid Build Coastguard Worker// CHECK: adrp    x0, foo     // encoding: [A,A,A,0x90'A']
24*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:                //   fixup A - offset: 0, value: foo, kind: fixup_aarch64_pcrel_adrp_imm21
25*9880d681SAndroid Build Coastguard Worker
26*9880d681SAndroid Build Coastguard Workeradr x0, #0xffffffff
27*9880d681SAndroid Build Coastguard Workeradrp x0, #0xffffffff
28*9880d681SAndroid Build Coastguard Workeradrp x0, #1
29*9880d681SAndroid Build Coastguard Worker// CHECK-ERRORS: error: expected label or encodable integer pc offset
30*9880d681SAndroid Build Coastguard Worker// CHECK-ERRORS: error: expected label or encodable integer pc offset
31*9880d681SAndroid Build Coastguard Worker// CHECK-ERRORS: error: expected label or encodable integer pc offset
32