annotate lld/test/mach-o/hello-world-arm64.yaml @ 150:1d019706d866

LLVM10
author anatofuz
date Thu, 13 Feb 2020 15:10:13 +0900
parents
children 0572611fdcc8
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 # RUN: ld64.lld -arch arm64 %s %p/Inputs/hello-world-arm64.yaml -o %t
anatofuz
parents:
diff changeset
2 # RUN: llvm-nm -m -n %t | FileCheck %s
anatofuz
parents:
diff changeset
3 # RUN: llvm-objdump -private-headers %t | FileCheck %s --check-prefix=CHECK-PRIVATE-HEADER
anatofuz
parents:
diff changeset
4 #
anatofuz
parents:
diff changeset
5 # Test that arm64 hello-world can be linked into a mach-o executable
anatofuz
parents:
diff changeset
6 #
anatofuz
parents:
diff changeset
7
anatofuz
parents:
diff changeset
8 --- !mach-o
anatofuz
parents:
diff changeset
9 arch: arm64
anatofuz
parents:
diff changeset
10 file-type: MH_OBJECT
anatofuz
parents:
diff changeset
11 flags: [ MH_SUBSECTIONS_VIA_SYMBOLS ]
anatofuz
parents:
diff changeset
12 sections:
anatofuz
parents:
diff changeset
13 - segment: __TEXT
anatofuz
parents:
diff changeset
14 section: __text
anatofuz
parents:
diff changeset
15 type: S_REGULAR
anatofuz
parents:
diff changeset
16 attributes: [ S_ATTR_PURE_INSTRUCTIONS, S_ATTR_SOME_INSTRUCTIONS ]
anatofuz
parents:
diff changeset
17 alignment: 2
anatofuz
parents:
diff changeset
18 address: 0x0000000000000000
anatofuz
parents:
diff changeset
19 content: [ 0xFD, 0x7B, 0xBF, 0xA9, 0xFD, 0x03, 0x00, 0x91,
anatofuz
parents:
diff changeset
20 0x08, 0x00, 0x00, 0x90, 0x08, 0x01, 0x40, 0xF9,
anatofuz
parents:
diff changeset
21 0x00, 0x01, 0x40, 0xF9, 0x01, 0x00, 0x00, 0x90,
anatofuz
parents:
diff changeset
22 0x21, 0x00, 0x00, 0x91, 0x00, 0x00, 0x00, 0x94,
anatofuz
parents:
diff changeset
23 0x00, 0x00, 0x80, 0x52, 0xFD, 0x7B, 0xC1, 0xA8,
anatofuz
parents:
diff changeset
24 0xC0, 0x03, 0x5F, 0xD6 ]
anatofuz
parents:
diff changeset
25 relocations:
anatofuz
parents:
diff changeset
26 - offset: 0x0000001C
anatofuz
parents:
diff changeset
27 type: ARM64_RELOC_BRANCH26
anatofuz
parents:
diff changeset
28 length: 2
anatofuz
parents:
diff changeset
29 pc-rel: true
anatofuz
parents:
diff changeset
30 extern: true
anatofuz
parents:
diff changeset
31 symbol: 5
anatofuz
parents:
diff changeset
32 - offset: 0x00000018
anatofuz
parents:
diff changeset
33 type: ARM64_RELOC_PAGEOFF12
anatofuz
parents:
diff changeset
34 length: 2
anatofuz
parents:
diff changeset
35 pc-rel: false
anatofuz
parents:
diff changeset
36 extern: true
anatofuz
parents:
diff changeset
37 symbol: 1
anatofuz
parents:
diff changeset
38 - offset: 0x00000014
anatofuz
parents:
diff changeset
39 type: ARM64_RELOC_PAGE21
anatofuz
parents:
diff changeset
40 length: 2
anatofuz
parents:
diff changeset
41 pc-rel: true
anatofuz
parents:
diff changeset
42 extern: true
anatofuz
parents:
diff changeset
43 symbol: 1
anatofuz
parents:
diff changeset
44 - offset: 0x0000000C
anatofuz
parents:
diff changeset
45 type: ARM64_RELOC_GOT_LOAD_PAGEOFF12
anatofuz
parents:
diff changeset
46 length: 2
anatofuz
parents:
diff changeset
47 pc-rel: false
anatofuz
parents:
diff changeset
48 extern: true
anatofuz
parents:
diff changeset
49 symbol: 4
anatofuz
parents:
diff changeset
50 - offset: 0x00000008
anatofuz
parents:
diff changeset
51 type: ARM64_RELOC_GOT_LOAD_PAGE21
anatofuz
parents:
diff changeset
52 length: 2
anatofuz
parents:
diff changeset
53 pc-rel: true
anatofuz
parents:
diff changeset
54 extern: true
anatofuz
parents:
diff changeset
55 symbol: 4
anatofuz
parents:
diff changeset
56 - segment: __TEXT
anatofuz
parents:
diff changeset
57 section: __cstring
anatofuz
parents:
diff changeset
58 type: S_CSTRING_LITERALS
anatofuz
parents:
diff changeset
59 attributes: [ ]
anatofuz
parents:
diff changeset
60 address: 0x000000000000002C
anatofuz
parents:
diff changeset
61 content: [ 0x68, 0x65, 0x6C, 0x6C, 0x6F, 0x0A, 0x00 ]
anatofuz
parents:
diff changeset
62 local-symbols:
anatofuz
parents:
diff changeset
63 - name: ltmp0
anatofuz
parents:
diff changeset
64 type: N_SECT
anatofuz
parents:
diff changeset
65 sect: 1
anatofuz
parents:
diff changeset
66 value: 0x0000000000000000
anatofuz
parents:
diff changeset
67 - name: l_.str
anatofuz
parents:
diff changeset
68 type: N_SECT
anatofuz
parents:
diff changeset
69 sect: 2
anatofuz
parents:
diff changeset
70 value: 0x000000000000002C
anatofuz
parents:
diff changeset
71 - name: ltmp1
anatofuz
parents:
diff changeset
72 type: N_SECT
anatofuz
parents:
diff changeset
73 sect: 2
anatofuz
parents:
diff changeset
74 value: 0x000000000000002C
anatofuz
parents:
diff changeset
75 global-symbols:
anatofuz
parents:
diff changeset
76 - name: _main
anatofuz
parents:
diff changeset
77 type: N_SECT
anatofuz
parents:
diff changeset
78 scope: [ N_EXT ]
anatofuz
parents:
diff changeset
79 sect: 1
anatofuz
parents:
diff changeset
80 value: 0x0000000000000000
anatofuz
parents:
diff changeset
81 undefined-symbols:
anatofuz
parents:
diff changeset
82 - name: ___stdoutp
anatofuz
parents:
diff changeset
83 type: N_UNDF
anatofuz
parents:
diff changeset
84 scope: [ N_EXT ]
anatofuz
parents:
diff changeset
85 value: 0x0000000000000000
anatofuz
parents:
diff changeset
86 - name: _fprintf
anatofuz
parents:
diff changeset
87 type: N_UNDF
anatofuz
parents:
diff changeset
88 scope: [ N_EXT ]
anatofuz
parents:
diff changeset
89 value: 0x0000000000000000
anatofuz
parents:
diff changeset
90 ...
anatofuz
parents:
diff changeset
91
anatofuz
parents:
diff changeset
92 # CHECK: (undefined) external ___stdoutp (from libSystem)
anatofuz
parents:
diff changeset
93 # CHECK: (undefined) external _fprintf (from libSystem)
anatofuz
parents:
diff changeset
94 # CHECK: (undefined) external dyld_stub_binder (from libSystem)
anatofuz
parents:
diff changeset
95 # CHECK: {{[0-9a-f]+}} (__TEXT,__text) external _main
anatofuz
parents:
diff changeset
96
anatofuz
parents:
diff changeset
97 # CHECK-PRIVATE-HEADER: sectname __stubs
anatofuz
parents:
diff changeset
98 # CHECK-PRIVATE-HEADER-NEXT: segname __TEXT
anatofuz
parents:
diff changeset
99 # CHECK-PRIVATE-HEADER-NEXT: addr
anatofuz
parents:
diff changeset
100 # CHECK-PRIVATE-HEADER-NEXT: size
anatofuz
parents:
diff changeset
101 # CHECK-PRIVATE-HEADER-NEXT: offset
anatofuz
parents:
diff changeset
102 # CHECK-PRIVATE-HEADER-NEXT: align 2^1 (2)