]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - test/ELF/basic-ppc64.s
Vendor import of lld trunk r338150:
[FreeBSD/FreeBSD.git] / test / ELF / basic-ppc64.s
1 # REQUIRES: ppc
2 # # RUN: llvm-mc -filetype=obj -triple=powerpc64le-unknown-linux %s -o %t
3 # RUN: ld.lld --hash-style=sysv -discard-all -shared %t -o %t2
4 # RUN: llvm-readobj -file-headers -sections -section-data -program-headers %t2 | FileCheck %s
5 .abiversion 2
6 # Exits with return code 55 on linux.
7 .text
8   li 0,1
9   li 3,55
10   sc
11
12 // CHECK:Format: ELF64-ppc64
13 // CHECK-NEXT:Arch: powerpc64le
14 // CHECK-NEXT:AddressSize: 64bit
15 // CHECK-NEXT:LoadName: 
16 // CHECK-NEXT:ElfHeader {
17 // CHECK-NEXT:  Ident {
18 // CHECK-NEXT:    Magic: (7F 45 4C 46)
19 // CHECK-NEXT:    Class: 64-bit (0x2)
20 // CHECK-NEXT:    DataEncoding: LittleEndian (0x1)
21 // CHECK-NEXT:    FileVersion: 1
22 // CHECK-NEXT:    OS/ABI: SystemV (0x0)
23 // CHECK-NEXT:    ABIVersion: 0
24 // CHECK-NEXT:    Unused: (00 00 00 00 00 00 00)
25 // CHECK-NEXT:  }
26 // CHECK-NEXT:  Type: SharedObject (0x3)
27 // CHECK-NEXT:  Machine: EM_PPC64 (0x15)
28 // CHECK-NEXT:  Version: 1
29 // CHECK-NEXT:  Entry: 0x10000
30 // CHECK-NEXT:  ProgramHeaderOffset: 0x40
31 // CHECK-NEXT:  SectionHeaderOffset:
32 // CHECK-NEXT:  Flags [ (0x2)
33 // CHECK-NEXT:    0x2
34 // CHECK-NEXT:  ]
35 // CHECK-NEXT:  HeaderSize: 64
36 // CHECK-NEXT:  ProgramHeaderEntrySize: 56
37 // CHECK-NEXT:  ProgramHeaderCount: 7
38 // CHECK-NEXT:  SectionHeaderEntrySize: 64
39 // CHECK-NEXT:  SectionHeaderCount: 10
40 // CHECK-NEXT:  StringTableSectionIndex: 8
41 // CHECK-NEXT:}
42 // CHECK-NEXT:Sections [
43 // CHECK-NEXT:  Section {
44 // CHECK-NEXT:    Index: 0
45 // CHECK-NEXT:    Name:  (0)
46 // CHECK-NEXT:    Type: SHT_NULL (0x0)
47 // CHECK-NEXT:    Flags [ (0x0)
48 // CHECK-NEXT:    ]
49 // CHECK-NEXT:    Address: 0x0
50 // CHECK-NEXT:    Offset: 0x0
51 // CHECK-NEXT:    Size: 0
52 // CHECK-NEXT:    Link: 0
53 // CHECK-NEXT:    Info: 0
54 // CHECK-NEXT:    AddressAlignment: 0
55 // CHECK-NEXT:    EntrySize: 0
56 // CHECK-NEXT:    SectionData (
57 // CHECK-NEXT:    )
58 // CHECK-NEXT:  }
59 // CHECK-NEXT:  Section {
60 // CHECK-NEXT:    Index: 1
61 // CHECK-NEXT:    Name: .dynsym (1)
62 // CHECK-NEXT:    Type: SHT_DYNSYM (0xB)
63 // CHECK-NEXT:    Flags [ (0x2)
64 // CHECK-NEXT:      SHF_ALLOC (0x2)
65 // CHECK-NEXT:    ]
66 // CHECK-NEXT:    Address: 0x1C8
67 // CHECK-NEXT:    Offset: 0x1C8
68 // CHECK-NEXT:    Size: 24
69 // CHECK-NEXT:    Link: 3
70 // CHECK-NEXT:    Info: 1
71 // CHECK-NEXT:    AddressAlignment: 8
72 // CHECK-NEXT:    EntrySize: 24
73 // CHECK-NEXT:    SectionData (
74 // CHECK-NEXT:      0000: 00000000 00000000 00000000 00000000  |................|
75 // CHECK-NEXT:      0010: 00000000 00000000                    |........|
76 // CHECK-NEXT:    )
77 // CHECK-NEXT:  }
78 // CHECK-NEXT:  Section {
79 // CHECK-NEXT:    Index: 2
80 // CHECK-NEXT:    Name: .hash (9)
81 // CHECK-NEXT:    Type: SHT_HASH (0x5)
82 // CHECK-NEXT:    Flags [ (0x2)
83 // CHECK-NEXT:      SHF_ALLOC (0x2)
84 // CHECK-NEXT:    ]
85 // CHECK-NEXT:    Address: 0x1E0
86 // CHECK-NEXT:    Offset: 0x1E0
87 // CHECK-NEXT:    Size: 16
88 // CHECK-NEXT:    Link: 1
89 // CHECK-NEXT:    Info: 0
90 // CHECK-NEXT:    AddressAlignment: 4
91 // CHECK-NEXT:    EntrySize: 4
92 // CHECK-NEXT:    SectionData (
93 // CHECK-NEXT:      0000: 01000000 01000000 00000000 00000000  |................|
94 // CHECK-NEXT:    )
95 // CHECK-NEXT:  }
96 // CHECK-NEXT:  Section {
97 // CHECK-NEXT:    Index: 3
98 // CHECK-NEXT:    Name: .dynstr (15)
99 // CHECK-NEXT:    Type: SHT_STRTAB (0x3)
100 // CHECK-NEXT:    Flags [ (0x2)
101 // CHECK-NEXT:      SHF_ALLOC (0x2)
102 // CHECK-NEXT:    ]
103 // CHECK-NEXT:    Address: 0x1F0
104 // CHECK-NEXT:    Offset: 0x1F0
105 // CHECK-NEXT:    Size: 1
106 // CHECK-NEXT:    Link: 0
107 // CHECK-NEXT:    Info: 0
108 // CHECK-NEXT:    AddressAlignment: 1
109 // CHECK-NEXT:    EntrySize: 0
110 // CHECK-NEXT:    SectionData (
111 // CHECK-NEXT:      0000: 00                                   |.|
112 // CHECK-NEXT:    )
113 // CHECK-NEXT:  }
114 // CHECK-NEXT:  Section {
115 // CHECK-NEXT:    Index: 4
116 // CHECK-NEXT:    Name: .text (23)
117 // CHECK-NEXT:    Type: SHT_PROGBITS (0x1)
118 // CHECK-NEXT:    Flags [ (0x6)
119 // CHECK-NEXT:      SHF_ALLOC (0x2)
120 // CHECK-NEXT:      SHF_EXECINSTR (0x4)
121 // CHECK-NEXT:    ]
122 // CHECK-NEXT:    Address: 0x10000
123 // CHECK-NEXT:    Offset: 0x10000
124 // CHECK-NEXT:    Size: 12
125 // CHECK-NEXT:    Link: 0
126 // CHECK-NEXT:    Info: 0
127 // CHECK-NEXT:    AddressAlignment: 4
128 // CHECK-NEXT:    EntrySize: 0
129 // CHECK-NEXT:    SectionData (
130 // CHECK-NEXT:      0000: 01000038 37006038 02000044           |...87.`8...D|
131 // CHECK-NEXT:    )
132 // CHECK-NEXT:  }
133 // CHECK-NEXT:  Section {
134 // CHECK-NEXT:    Index: 5
135 // CHECK-NEXT:    Name: .dynamic (29)
136 // CHECK-NEXT:    Type: SHT_DYNAMIC (0x6)
137 // CHECK-NEXT:    Flags [ (0x3)
138 // CHECK-NEXT:      SHF_ALLOC (0x2)
139 // CHECK-NEXT:      SHF_WRITE (0x1)
140 // CHECK-NEXT:    ]
141 // CHECK-NEXT:    Address: 0x20000
142 // CHECK-NEXT:    Offset: 0x20000
143 // CHECK-NEXT:    Size: 96
144 // CHECK-NEXT:    Link: 3
145 // CHECK-NEXT:    Info: 0
146 // CHECK-NEXT:    AddressAlignment: 8
147 // CHECK-NEXT:    EntrySize: 16
148 // CHECK-NEXT:    SectionData (
149 // CHECK-NEXT:      0000: 06000000 00000000 C8010000 00000000  |................|
150 // CHECK-NEXT:      0010: 0B000000 00000000 18000000 00000000  |................|
151 // CHECK-NEXT:      0020: 05000000 00000000 F0010000 00000000  |................|
152 // CHECK-NEXT:      0030: 0A000000 00000000 01000000 00000000  |................|
153 // CHECK-NEXT:      0040: 04000000 00000000 E0010000 00000000  |................|
154 // CHECK-NEXT:      0050: 00000000 00000000 00000000 00000000  |................|
155 // CHECK-NEXT:    )
156 // CHECK-NEXT:  }
157 // CHECK-NEXT:  Section {
158 // CHECK-NEXT:    Index: 6
159 // CHECK-NEXT:    Name: .comment (38)
160 // CHECK-NEXT:    Type: SHT_PROGBITS (0x1)
161 // CHECK-NEXT:    Flags [ (0x30)
162 // CHECK-NEXT:      SHF_MERGE (0x10)
163 // CHECK-NEXT:      SHF_STRINGS (0x20)
164 // CHECK-NEXT:    ]
165 // CHECK-NEXT:    Address: 0x0
166 // CHECK-NEXT:    Offset: 0x20060
167 // CHECK-NEXT:    Size: 8
168 // CHECK-NEXT:    Link: 0
169 // CHECK-NEXT:    Info: 0
170 // CHECK-NEXT:    AddressAlignment: 1
171 // CHECK-NEXT:    EntrySize: 1
172 // CHECK-NEXT:    SectionData (
173 // CHECK-NEXT:      0000: 4C4C4420 312E3000                    |LLD 1.0.|
174 // CHECK-NEXT:    )
175 // CHECK-NEXT:  }
176 // CHECK-NEXT:  Section {
177 // CHECK-NEXT:    Index: 7
178 // CHECK-NEXT:    Name: .symtab (47)
179 // CHECK-NEXT:    Type: SHT_SYMTAB (0x2)
180 // CHECK-NEXT:    Flags [ (0x0)
181 // CHECK-NEXT:    ]
182 // CHECK-NEXT:    Address: 0x0
183 // CHECK-NEXT:    Offset: 0x20068
184 // CHECK-NEXT:    Size: 48
185 // CHECK-NEXT:    Link: 9
186 // CHECK-NEXT:    Info: 2
187 // CHECK-NEXT:    AddressAlignment: 8
188 // CHECK-NEXT:    EntrySize: 24
189 // CHECK-NEXT:    SectionData (
190 // CHECK-NEXT:      0000: 00000000 00000000 00000000 00000000  |................|
191 // CHECK-NEXT:      0010: 00000000 00000000 01000000 00020500  |................|
192 // CHECK-NEXT:      0020: 00000200 00000000 00000000 00000000  |................|
193 // CHECK-NEXT:    )
194 // CHECK-NEXT:  }
195 // CHECK-NEXT:  Section {
196 // CHECK-NEXT:    Index: 8
197 // CHECK-NEXT:    Name: .shstrtab (55)
198 // CHECK-NEXT:    Type: SHT_STRTAB (0x3)
199 // CHECK-NEXT:    Flags [ (0x0)
200 // CHECK-NEXT:    ]
201 // CHECK-NEXT:    Address: 0x0
202 // CHECK-NEXT:    Offset: 0x20098
203 // CHECK-NEXT:    Size: 73
204 // CHECK-NEXT:    Link: 0
205 // CHECK-NEXT:    Info: 0
206 // CHECK-NEXT:    AddressAlignment: 1
207 // CHECK-NEXT:    EntrySize: 0
208 // CHECK-NEXT:    SectionData (
209 // CHECK-NEXT:      0000: 002E6479 6E73796D 002E6861 7368002E  |..dynsym..hash..|
210 // CHECK-NEXT:      0010: 64796E73 7472002E 74657874 002E6479  |dynstr..text..dy|
211 // CHECK-NEXT:      0020: 6E616D69 63002E63 6F6D6D65 6E74002E  |namic..comment..|
212 // CHECK-NEXT:      0030: 73796D74 6162002E 73687374 72746162  |symtab..shstrtab|
213 // CHECK-NEXT:      0040: 002E7374 72746162 00                 |..strtab.|
214 // CHECK-NEXT:    )
215 // CHECK-NEXT:  }
216 // CHECK-NEXT:  Section {
217 // CHECK-NEXT:    Index: 9
218 // CHECK-NEXT:    Name: .strtab (65)
219 // CHECK-NEXT:    Type: SHT_STRTAB (0x3)
220 // CHECK-NEXT:    Flags [ (0x0)
221 // CHECK-NEXT:    ]
222 // CHECK-NEXT:    Address: 0x0
223 // CHECK-NEXT:    Offset: 0x200E1
224 // CHECK-NEXT:    Size: 10
225 // CHECK-NEXT:    Link: 0
226 // CHECK-NEXT:    Info: 0
227 // CHECK-NEXT:    AddressAlignment: 1
228 // CHECK-NEXT:    EntrySize: 0
229 // CHECK-NEXT:    SectionData (
230 // CHECK-NEXT:      0000: 005F4459 4E414D49 4300               |._DYNAMIC.|
231 // CHECK-NEXT:    )
232 // CHECK-NEXT:  }
233 // CHECK-NEXT:]
234 // CHECK-NEXT:ProgramHeaders [
235 // CHECK-NEXT:  ProgramHeader {
236 // CHECK-NEXT:    Type: PT_PHDR (0x6)
237 // CHECK-NEXT:    Offset: 0x40
238 // CHECK-NEXT:    VirtualAddress: 0x40
239 // CHECK-NEXT:    PhysicalAddress: 0x40
240 // CHECK-NEXT:    FileSize: 392
241 // CHECK-NEXT:    MemSize: 392
242 // CHECK-NEXT:    Flags [ (0x4)
243 // CHECK-NEXT:      PF_R (0x4)
244 // CHECK-NEXT:    ]
245 // CHECK-NEXT:    Alignment: 8
246 // CHECK-NEXT:  }
247 // CHECK-NEXT:  ProgramHeader {
248 // CHECK-NEXT:    Type: PT_LOAD (0x1)
249 // CHECK-NEXT:    Offset: 0x0
250 // CHECK-NEXT:    VirtualAddress: 0x0
251 // CHECK-NEXT:    PhysicalAddress: 0x0
252 // CHECK-NEXT:    FileSize: 497
253 // CHECK-NEXT:    MemSize: 497
254 // CHECK-NEXT:    Flags [ (0x4)
255 // CHECK-NEXT:      PF_R (0x4)
256 // CHECK-NEXT:    ]
257 // CHECK-NEXT:    Alignment: 65536
258 // CHECK-NEXT:  }
259 // CHECK-NEXT:  ProgramHeader {
260 // CHECK-NEXT:    Type: PT_LOAD (0x1)
261 // CHECK-NEXT:    Offset: 0x10000
262 // CHECK-NEXT:    VirtualAddress: 0x10000
263 // CHECK-NEXT:    PhysicalAddress: 0x10000
264 // CHECK-NEXT:    FileSize: 12
265 // CHECK-NEXT:    MemSize: 12
266 // CHECK-NEXT:    Flags [ (0x5)
267 // CHECK-NEXT:      PF_R (0x4)
268 // CHECK-NEXT:      PF_X (0x1)
269 // CHECK-NEXT:    ]
270 // CHECK-NEXT:    Alignment: 65536
271 // CHECK-NEXT:  }
272 // CHECK-NEXT:  ProgramHeader {
273 // CHECK-NEXT:    Type: PT_LOAD (0x1)
274 // CHECK-NEXT:    Offset: 0x20000
275 // CHECK-NEXT:    VirtualAddress: 0x20000
276 // CHECK-NEXT:    PhysicalAddress: 0x20000
277 // CHECK-NEXT:    FileSize: 96
278 // CHECK-NEXT:    MemSize: 96
279 // CHECK-NEXT:    Flags [ (0x6)
280 // CHECK-NEXT:      PF_R (0x4)
281 // CHECK-NEXT:      PF_W (0x2)
282 // CHECK-NEXT:    ]
283 // CHECK-NEXT:    Alignment: 65536
284 // CHECK-NEXT:  }
285 // CHECK-NEXT:  ProgramHeader {
286 // CHECK-NEXT:    Type: PT_DYNAMIC (0x2)
287 // CHECK-NEXT:    Offset: 0x20000
288 // CHECK-NEXT:    VirtualAddress: 0x20000
289 // CHECK-NEXT:    PhysicalAddress: 0x20000
290 // CHECK-NEXT:    FileSize: 96
291 // CHECK-NEXT:    MemSize: 96
292 // CHECK-NEXT:    Flags [ (0x6)
293 // CHECK-NEXT:      PF_R (0x4)
294 // CHECK-NEXT:      PF_W (0x2)
295 // CHECK-NEXT:    ]
296 // CHECK-NEXT:    Alignment: 8
297 // CHECK-NEXT:  }
298 // CHECK-NEXT:  ProgramHeader {
299 // CHECK-NEXT:    Type: PT_GNU_RELRO (0x6474E552)
300 // CHECK-NEXT:    Offset: 0x20000
301 // CHECK-NEXT:    VirtualAddress: 0x20000
302 // CHECK-NEXT:    PhysicalAddress: 0x20000
303 // CHECK-NEXT:    FileSize: 96
304 // CHECK-NEXT:    MemSize: 4096
305 // CHECK-NEXT:    Flags [ (0x4)
306 // CHECK-NEXT:      PF_R (0x4)
307 // CHECK-NEXT:    ]
308 // CHECK-NEXT:    Alignment: 1
309 // CHECK-NEXT:  }
310 // CHECK-NEXT:  ProgramHeader {
311 // CHECK-NEXT:    Type: PT_GNU_STACK (0x6474E551)
312 // CHECK-NEXT:    Offset: 0x0
313 // CHECK-NEXT:    VirtualAddress: 0x0
314 // CHECK-NEXT:    PhysicalAddress: 0x0
315 // CHECK-NEXT:    FileSize: 0
316 // CHECK-NEXT:    MemSize: 0
317 // CHECK-NEXT:    Flags [ (0x6)
318 // CHECK-NEXT:      PF_R (0x4)
319 // CHECK-NEXT:      PF_W (0x2)
320 // CHECK-NEXT:    ]
321 // CHECK-NEXT:    Alignment: 0
322 // CHECK-NEXT:  }
323 // CHECK-NEXT:]