xref: /aosp_15_r20/external/llvm/test/MC/MachO/AArch64/mergeable.s (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker// RUN: llvm-mc -triple aarch64-apple-darwin14 %s -filetype=obj -o - | llvm-readobj -r --expand-relocs | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker// FIXME: the final relocation should be internal, but the linker doesn't
3*9880d681SAndroid Build Coastguard Worker// currently handle the it correctly.
4*9880d681SAndroid Build Coastguard Worker
5*9880d681SAndroid Build Coastguard Worker// Test that we "S + K" produce a relocation with a symbol, but just S produces
6*9880d681SAndroid Build Coastguard Worker// a relocation with the section.
7*9880d681SAndroid Build Coastguard Worker
8*9880d681SAndroid Build Coastguard Worker	.section	__TEXT,__literal4,4byte_literals
9*9880d681SAndroid Build Coastguard WorkerL0:
10*9880d681SAndroid Build Coastguard Worker	.long	42
11*9880d681SAndroid Build Coastguard Worker
12*9880d681SAndroid Build Coastguard Worker	.section	__TEXT,__cstring,cstring_literals
13*9880d681SAndroid Build Coastguard WorkerL1:
14*9880d681SAndroid Build Coastguard Worker	.asciz	"42"
15*9880d681SAndroid Build Coastguard Worker
16*9880d681SAndroid Build Coastguard Worker	.section	__DATA,__data
17*9880d681SAndroid Build Coastguard Worker	.quad	L0
18*9880d681SAndroid Build Coastguard Worker	.quad	L0 + 1
19*9880d681SAndroid Build Coastguard Worker	.quad	L1
20*9880d681SAndroid Build Coastguard Worker	.quad	L1 + 1
21*9880d681SAndroid Build Coastguard Worker
22*9880d681SAndroid Build Coastguard Worker// CHECK:      Relocations [
23*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:   Section __data {
24*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:     Relocation {
25*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:       Offset: 0x18
26*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:       PCRel: 0
27*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:       Length: 3
28*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:       Type: ARM64_RELOC_UNSIGNED (0)
29*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:       Symbol: L1
30*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:     }
31*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:     Relocation {
32*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:       Offset: 0x10
33*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:       PCRel: 0
34*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:       Length: 3
35*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:       Type: ARM64_RELOC_UNSIGNED (0)
36*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:       Symbol: L1
37*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:     }
38*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:     Relocation {
39*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:       Offset: 0x8
40*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:       PCRel: 0
41*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:       Length: 3
42*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:       Type: ARM64_RELOC_UNSIGNED (0)
43*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:       Symbol: L0
44*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:     }
45*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:     Relocation {
46*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:       Offset: 0x0
47*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:       PCRel: 0
48*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:       Length: 3
49*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:       Type: ARM64_RELOC_UNSIGNED (0)
50*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:       Symbol: L0
51*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:     }
52*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT:   }
53*9880d681SAndroid Build Coastguard Worker// CHECK-NEXT: ]
54