As per section 4.2.2 of the PowerPC ELFv2 ABI, this value tells the dynamic linker which optimizations it is allowed to do. Specifically, the higher order bit of the two tells the dynamic linker that there may be multiple TOC pointers in the binary. When we resolve any NOTOC relocations during linking, we need to set this value because we may be calling TOC functions from NOTOC functions when the NOTOC function already clobbered the TOC pointer. In practice, this ensures that the PLT resolver always resolves the call to the GEP (global entry point) of the TOC function (which will set up the TOC for the TOC function). Original patch by nemanjai Reviewed By: MaskRay Differential Revision: https://reviews.llvm.org/D150631
361 lines
12 KiB
ArmAsm
361 lines
12 KiB
ArmAsm
# REQUIRES: ppc
|
|
# RUN: llvm-mc -filetype=obj -triple=powerpc64le-unknown-linux %s -o %t.o
|
|
# RUN: ld.lld --hash-style=sysv -discard-all -shared %t.o -o %t.so
|
|
# RUN: llvm-readobj --file-headers --sections --section-data -l %t.so | FileCheck --check-prefixes=CHECK,LE %s
|
|
|
|
# RUN: llvm-mc -filetype=obj -triple=powerpc64-unknown-linux %s -o %t.o
|
|
# RUN: ld.lld --hash-style=sysv -discard-all -shared %t.o -o %t.so
|
|
# RUN: llvm-readobj --file-headers --sections --section-data -l %t.so | FileCheck --check-prefixes=CHECK,BE %s
|
|
|
|
.abiversion 2
|
|
# Exits with return code 55 on linux.
|
|
.text
|
|
li 0,1
|
|
li 3,55
|
|
sc
|
|
|
|
// CHECK: Format: elf64-powerpc
|
|
// LE-NEXT: Arch: powerpc64le
|
|
// BE-NEXT: Arch: powerpc64{{$}}
|
|
// CHECK-NEXT: AddressSize: 64bit
|
|
// CHECK-NEXT: LoadName:
|
|
// CHECK-NEXT: ElfHeader {
|
|
// CHECK-NEXT: Ident {
|
|
// CHECK-NEXT: Magic: (7F 45 4C 46)
|
|
// CHECK-NEXT: Class: 64-bit (0x2)
|
|
// LE-NEXT: DataEncoding: LittleEndian (0x1)
|
|
// BE-NEXT: DataEncoding: BigEndian (0x2)
|
|
// CHECK-NEXT: FileVersion: 1
|
|
// CHECK-NEXT: OS/ABI: SystemV (0x0)
|
|
// CHECK-NEXT: ABIVersion: 0
|
|
// CHECK-NEXT: Unused: (00 00 00 00 00 00 00)
|
|
// CHECK-NEXT: }
|
|
// CHECK-NEXT: Type: SharedObject (0x3)
|
|
// CHECK-NEXT: Machine: EM_PPC64 (0x15)
|
|
// CHECK-NEXT: Version: 1
|
|
// CHECK-NEXT: Entry: 0x0
|
|
// CHECK-NEXT: ProgramHeaderOffset: 0x40
|
|
// CHECK-NEXT: SectionHeaderOffset: 0x340
|
|
// CHECK-NEXT: Flags [ (0x2)
|
|
// CHECK-NEXT: 0x2
|
|
// CHECK-NEXT: ]
|
|
// CHECK-NEXT: HeaderSize: 64
|
|
// CHECK-NEXT: ProgramHeaderEntrySize: 56
|
|
// CHECK-NEXT: ProgramHeaderCount: 7
|
|
// CHECK-NEXT: SectionHeaderEntrySize: 64
|
|
// CHECK-NEXT: SectionHeaderCount: 11
|
|
// CHECK-NEXT: StringTableSectionIndex: 9
|
|
// CHECK-NEXT:}
|
|
// CHECK-NEXT:Sections [
|
|
// CHECK-NEXT: Section {
|
|
// CHECK-NEXT: Index: 0
|
|
// CHECK-NEXT: Name: (0)
|
|
// CHECK-NEXT: Type: SHT_NULL (0x0)
|
|
// CHECK-NEXT: Flags [ (0x0)
|
|
// CHECK-NEXT: ]
|
|
// CHECK-NEXT: Address: 0x0
|
|
// CHECK-NEXT: Offset: 0x0
|
|
// CHECK-NEXT: Size: 0
|
|
// CHECK-NEXT: Link: 0
|
|
// CHECK-NEXT: Info: 0
|
|
// CHECK-NEXT: AddressAlignment: 0
|
|
// CHECK-NEXT: EntrySize: 0
|
|
// CHECK-NEXT: SectionData (
|
|
// CHECK-NEXT: )
|
|
// CHECK-NEXT: }
|
|
// CHECK-NEXT: Section {
|
|
// CHECK-NEXT: Index: 1
|
|
// CHECK-NEXT: Name: .dynsym (1)
|
|
// CHECK-NEXT: Type: SHT_DYNSYM (0xB)
|
|
// CHECK-NEXT: Flags [ (0x2)
|
|
// CHECK-NEXT: SHF_ALLOC (0x2)
|
|
// CHECK-NEXT: ]
|
|
// CHECK-NEXT: Address: 0x200
|
|
// CHECK-NEXT: Offset: 0x200
|
|
// CHECK-NEXT: Size: 24
|
|
// CHECK-NEXT: Link: 3
|
|
// CHECK-NEXT: Info: 1
|
|
// CHECK-NEXT: AddressAlignment: 8
|
|
// CHECK-NEXT: EntrySize: 24
|
|
// CHECK-NEXT: SectionData (
|
|
// CHECK-NEXT: 0000: 00000000 00000000 00000000 00000000 |................|
|
|
// CHECK-NEXT: 0010: 00000000 00000000 |........|
|
|
// CHECK-NEXT: )
|
|
// CHECK-NEXT: }
|
|
// CHECK-NEXT: Section {
|
|
// CHECK-NEXT: Index: 2
|
|
// CHECK-NEXT: Name: .hash (9)
|
|
// CHECK-NEXT: Type: SHT_HASH (0x5)
|
|
// CHECK-NEXT: Flags [ (0x2)
|
|
// CHECK-NEXT: SHF_ALLOC (0x2)
|
|
// CHECK-NEXT: ]
|
|
// CHECK-NEXT: Address: 0x218
|
|
// CHECK-NEXT: Offset: 0x218
|
|
// CHECK-NEXT: Size: 16
|
|
// CHECK-NEXT: Link: 1
|
|
// CHECK-NEXT: Info: 0
|
|
// CHECK-NEXT: AddressAlignment: 4
|
|
// CHECK-NEXT: EntrySize: 4
|
|
// CHECK-NEXT: SectionData (
|
|
// LE-NEXT: 0000: 01000000 01000000 00000000 00000000
|
|
// BE-NEXT: 0000: 00000001 00000001 00000000 00000000
|
|
// CHECK-NEXT: )
|
|
// CHECK-NEXT: }
|
|
// CHECK-NEXT: Section {
|
|
// CHECK-NEXT: Index: 3
|
|
// CHECK-NEXT: Name: .dynstr (15)
|
|
// CHECK-NEXT: Type: SHT_STRTAB (0x3)
|
|
// CHECK-NEXT: Flags [ (0x2)
|
|
// CHECK-NEXT: SHF_ALLOC (0x2)
|
|
// CHECK-NEXT: ]
|
|
// CHECK-NEXT: Address: 0x228
|
|
// CHECK-NEXT: Offset: 0x228
|
|
// CHECK-NEXT: Size: 1
|
|
// CHECK-NEXT: Link: 0
|
|
// CHECK-NEXT: Info: 0
|
|
// CHECK-NEXT: AddressAlignment: 1
|
|
// CHECK-NEXT: EntrySize: 0
|
|
// CHECK-NEXT: SectionData (
|
|
// CHECK-NEXT: 0000: 00 |.|
|
|
// CHECK-NEXT: )
|
|
// CHECK-NEXT: }
|
|
// CHECK-NEXT: Section {
|
|
// CHECK-NEXT: Index: 4
|
|
// CHECK-NEXT: Name: .text (23)
|
|
// CHECK-NEXT: Type: SHT_PROGBITS (0x1)
|
|
// CHECK-NEXT: Flags [ (0x6)
|
|
// CHECK-NEXT: SHF_ALLOC (0x2)
|
|
// CHECK-NEXT: SHF_EXECINSTR (0x4)
|
|
// CHECK-NEXT: ]
|
|
// CHECK-NEXT: Address: 0x1022C
|
|
// CHECK-NEXT: Offset: 0x22C
|
|
// CHECK-NEXT: Size: 12
|
|
// CHECK-NEXT: Link: 0
|
|
// CHECK-NEXT: Info: 0
|
|
// CHECK-NEXT: AddressAlignment: 4
|
|
// CHECK-NEXT: EntrySize: 0
|
|
// CHECK-NEXT: SectionData (
|
|
// LE-NEXT: 0000: 01000038 37006038 02000044
|
|
// BE-NEXT: 0000: 38000001 38600037 44000002
|
|
// CHECK-NEXT: )
|
|
// CHECK-NEXT: }
|
|
// CHECK-NEXT: Section {
|
|
// CHECK-NEXT: Index: 5
|
|
// CHECK-NEXT: Name: .dynamic (29)
|
|
// CHECK-NEXT: Type: SHT_DYNAMIC (0x6)
|
|
// CHECK-NEXT: Flags [ (0x3)
|
|
// CHECK-NEXT: SHF_ALLOC (0x2)
|
|
// CHECK-NEXT: SHF_WRITE (0x1)
|
|
// CHECK-NEXT: ]
|
|
// CHECK-NEXT: Address: 0x20238
|
|
// CHECK-NEXT: Offset: 0x238
|
|
// CHECK-NEXT: Size: 112
|
|
// CHECK-NEXT: Link: 3
|
|
// CHECK-NEXT: Info: 0
|
|
// CHECK-NEXT: AddressAlignment: 8
|
|
// CHECK-NEXT: EntrySize: 16
|
|
// CHECK-NEXT: SectionData (
|
|
// LE-NEXT: 0000: 06000000 00000000 00020000 00000000 |
|
|
// LE-NEXT: 0010: 0B000000 00000000 18000000 00000000 |
|
|
// LE-NEXT: 0020: 05000000 00000000 28020000 00000000 |
|
|
// LE-NEXT: 0030: 0A000000 00000000 01000000 00000000 |
|
|
// LE-NEXT: 0040: 04000000 00000000 18020000 00000000 |
|
|
// LE-NEXT: 0050: 03000070 00000000 00000000 00000000 |
|
|
// LE-NEXT: 0060: 00000000 00000000 00000000 00000000 |
|
|
// BE-NEXT: 0000: 00000000 00000006 00000000 00000200 |
|
|
// BE-NEXT: 0010: 00000000 0000000B 00000000 00000018 |
|
|
// BE-NEXT: 0020: 00000000 00000005 00000000 00000228 |
|
|
// BE-NEXT: 0030: 00000000 0000000A 00000000 00000001 |
|
|
// BE-NEXT: 0040: 00000000 00000004 00000000 00000218 |
|
|
// BE-NEXT: 0050: 00000000 70000003 00000000 00000000 |
|
|
// BE-NEXT: 0060: 00000000 00000000 00000000 00000000 |
|
|
// CHECK-NEXT: )
|
|
// CHECK-NEXT: }
|
|
// CHECK-NEXT: Section {
|
|
// CHECK-NEXT: Index: 6
|
|
// CHECK-NEXT: Name: .branch_lt (38)
|
|
// CHECK-NEXT: Type: SHT_NOBITS (0x8)
|
|
// CHECK-NEXT: Flags [ (0x3)
|
|
// CHECK-NEXT: SHF_ALLOC (0x2)
|
|
// CHECK-NEXT: SHF_WRITE (0x1)
|
|
// CHECK-NEXT: ]
|
|
// CHECK-NEXT: Address: 0x302A8
|
|
// CHECK-NEXT: Offset: 0x2A8
|
|
// CHECK-NEXT: Size: 0
|
|
// CHECK-NEXT: Link: 0
|
|
// CHECK-NEXT: Info: 0
|
|
// CHECK-NEXT: AddressAlignment: 8
|
|
// CHECK-NEXT: EntrySize: 0
|
|
// CHECK-NEXT: }
|
|
// CHECK-NEXT: Section {
|
|
// CHECK-NEXT: Index: 7
|
|
// CHECK-NEXT: Name: .comment (49)
|
|
// CHECK-NEXT: Type: SHT_PROGBITS (0x1)
|
|
// CHECK-NEXT: Flags [ (0x30)
|
|
// CHECK-NEXT: SHF_MERGE (0x10)
|
|
// CHECK-NEXT: SHF_STRINGS (0x20)
|
|
// CHECK-NEXT: ]
|
|
// CHECK-NEXT: Address: 0x0
|
|
// CHECK-NEXT: Offset: 0x2A8
|
|
// CHECK-NEXT: Size: 8
|
|
// CHECK-NEXT: Link: 0
|
|
// CHECK-NEXT: Info: 0
|
|
// CHECK-NEXT: AddressAlignment: 1
|
|
// CHECK-NEXT: EntrySize: 1
|
|
// CHECK-NEXT: SectionData (
|
|
// CHECK-NEXT: 0000: 4C4C4420 312E3000 |LLD 1.0.|
|
|
// CHECK-NEXT: )
|
|
// CHECK-NEXT: }
|
|
// CHECK-NEXT: Section {
|
|
// CHECK-NEXT: Index: 8
|
|
// CHECK-NEXT: Name: .symtab (58)
|
|
// CHECK-NEXT: Type: SHT_SYMTAB (0x2)
|
|
// CHECK-NEXT: Flags [ (0x0)
|
|
// CHECK-NEXT: ]
|
|
// CHECK-NEXT: Address: 0x0
|
|
// CHECK-NEXT: Offset: 0x2B0
|
|
// CHECK-NEXT: Size: 48
|
|
// CHECK-NEXT: Link: 10
|
|
// CHECK-NEXT: Info: 2
|
|
// CHECK-NEXT: AddressAlignment: 8
|
|
// CHECK-NEXT: EntrySize: 24
|
|
// CHECK-NEXT: SectionData (
|
|
// LE-NEXT: 0000: 00000000 00000000 00000000 00000000
|
|
// LE-NEXT: 0010: 00000000 00000000 01000000 00020500
|
|
// LE-NEXT: 0020: 38020200 00000000 00000000 00000000
|
|
// BE-NEXT: 0000: 00000000 00000000 00000000 00000000
|
|
// BE-NEXT: 0010: 00000000 00000000 00000001 00020005
|
|
// BE-NEXT: 0020: 00000000 00020238 00000000 00000000
|
|
// CHECK-NEXT: )
|
|
// CHECK-NEXT: }
|
|
// CHECK-NEXT: Section {
|
|
// CHECK-NEXT: Index: 9
|
|
// CHECK-NEXT: Name: .shstrtab (66)
|
|
// CHECK-NEXT: Type: SHT_STRTAB (0x3)
|
|
// CHECK-NEXT: Flags [ (0x0)
|
|
// CHECK-NEXT: ]
|
|
// CHECK-NEXT: Address: 0x0
|
|
// CHECK-NEXT: Offset: 0x2E0
|
|
// CHECK-NEXT: Size: 84
|
|
// CHECK-NEXT: Link: 0
|
|
// CHECK-NEXT: Info: 0
|
|
// CHECK-NEXT: AddressAlignment: 1
|
|
// CHECK-NEXT: EntrySize: 0
|
|
// CHECK-NEXT: SectionData (
|
|
// CHECK-NEXT: 0000: 002E6479 6E73796D 002E6861 7368002E |..dynsym..hash..|
|
|
// CHECK-NEXT: 0010: 64796E73 7472002E 74657874 002E6479 |dynstr..text..dy|
|
|
// CHECK-NEXT: 0020: 6E616D69 63002E62 72616E63 685F6C74 |namic..branch_lt|
|
|
// CHECK-NEXT: 0030: 002E636F 6D6D656E 74002E73 796D7461 |..comment..symta|
|
|
// CHECK-NEXT: 0040: 62002E73 68737472 74616200 2E737472 |b..shstrtab..str|
|
|
// CHECK-NEXT: 0050: 74616200 |tab.|
|
|
// CHECK-NEXT: )
|
|
// CHECK-NEXT: }
|
|
// CHECK-NEXT: Section {
|
|
// CHECK-NEXT: Index: 10
|
|
// CHECK-NEXT: Name: .strtab (76)
|
|
// CHECK-NEXT: Type: SHT_STRTAB (0x3)
|
|
// CHECK-NEXT: Flags [ (0x0)
|
|
// CHECK-NEXT: ]
|
|
// CHECK-NEXT: Address: 0x0
|
|
// CHECK-NEXT: Offset: 0x334
|
|
// CHECK-NEXT: Size: 10
|
|
// CHECK-NEXT: Link: 0
|
|
// CHECK-NEXT: Info: 0
|
|
// CHECK-NEXT: AddressAlignment: 1
|
|
// CHECK-NEXT: EntrySize: 0
|
|
// CHECK-NEXT: SectionData (
|
|
// CHECK-NEXT: 0000: 005F4459 4E414D49 4300 |._DYNAMIC.|
|
|
// CHECK-NEXT: )
|
|
// CHECK-NEXT: }
|
|
// CHECK-NEXT:]
|
|
// CHECK-NEXT:ProgramHeaders [
|
|
// CHECK-NEXT: ProgramHeader {
|
|
// CHECK-NEXT: Type: PT_PHDR (0x6)
|
|
// CHECK-NEXT: Offset: 0x40
|
|
// CHECK-NEXT: VirtualAddress: 0x40
|
|
// CHECK-NEXT: PhysicalAddress: 0x40
|
|
// CHECK-NEXT: FileSize: 448
|
|
// CHECK-NEXT: MemSize: 448
|
|
// CHECK-NEXT: Flags [ (0x4)
|
|
// CHECK-NEXT: PF_R (0x4)
|
|
// CHECK-NEXT: ]
|
|
// CHECK-NEXT: Alignment: 8
|
|
// CHECK-NEXT: }
|
|
// CHECK-NEXT: ProgramHeader {
|
|
// CHECK-NEXT: Type: PT_LOAD (0x1)
|
|
// CHECK-NEXT: Offset: 0x0
|
|
// CHECK-NEXT: VirtualAddress: 0x0
|
|
// CHECK-NEXT: PhysicalAddress: 0x0
|
|
// CHECK-NEXT: FileSize: 553
|
|
// CHECK-NEXT: MemSize: 553
|
|
// CHECK-NEXT: Flags [ (0x4)
|
|
// CHECK-NEXT: PF_R (0x4)
|
|
// CHECK-NEXT: ]
|
|
// CHECK-NEXT: Alignment: 65536
|
|
// CHECK-NEXT: }
|
|
// CHECK-NEXT: ProgramHeader {
|
|
// CHECK-NEXT: Type: PT_LOAD (0x1)
|
|
// CHECK-NEXT: Offset: 0x22C
|
|
// CHECK-NEXT: VirtualAddress: 0x1022C
|
|
// CHECK-NEXT: PhysicalAddress: 0x1022C
|
|
// CHECK-NEXT: FileSize: 12
|
|
// CHECK-NEXT: MemSize: 12
|
|
// CHECK-NEXT: Flags [ (0x5)
|
|
// CHECK-NEXT: PF_R (0x4)
|
|
// CHECK-NEXT: PF_X (0x1)
|
|
// CHECK-NEXT: ]
|
|
// CHECK-NEXT: Alignment: 65536
|
|
// CHECK-NEXT: }
|
|
// CHECK-NEXT: ProgramHeader {
|
|
// CHECK-NEXT: Type: PT_LOAD (0x1)
|
|
// CHECK-NEXT: Offset: 0x238
|
|
// CHECK-NEXT: VirtualAddress: 0x20238
|
|
// CHECK-NEXT: PhysicalAddress: 0x20238
|
|
// CHECK-NEXT: FileSize: 112
|
|
// CHECK-NEXT: MemSize: 112
|
|
// CHECK-NEXT: Flags [ (0x6)
|
|
// CHECK-NEXT: PF_R (0x4)
|
|
// CHECK-NEXT: PF_W (0x2)
|
|
// CHECK-NEXT: ]
|
|
// CHECK-NEXT: Alignment: 65536
|
|
// CHECK-NEXT: }
|
|
// CHECK-NEXT: ProgramHeader {
|
|
// CHECK-NEXT: Type: PT_DYNAMIC (0x2)
|
|
// CHECK-NEXT: Offset: 0x238
|
|
// CHECK-NEXT: VirtualAddress: 0x20238
|
|
// CHECK-NEXT: PhysicalAddress: 0x20238
|
|
// CHECK-NEXT: FileSize: 112
|
|
// CHECK-NEXT: MemSize: 112
|
|
// CHECK-NEXT: Flags [ (0x6)
|
|
// CHECK-NEXT: PF_R (0x4)
|
|
// CHECK-NEXT: PF_W (0x2)
|
|
// CHECK-NEXT: ]
|
|
// CHECK-NEXT: Alignment: 8
|
|
// CHECK-NEXT: }
|
|
// CHECK-NEXT: ProgramHeader {
|
|
// CHECK-NEXT: Type: PT_GNU_RELRO (0x6474E552)
|
|
// CHECK-NEXT: Offset: 0x238
|
|
// CHECK-NEXT: VirtualAddress: 0x20238
|
|
// CHECK-NEXT: PhysicalAddress: 0x20238
|
|
// CHECK-NEXT: FileSize: 112
|
|
// CHECK-NEXT: MemSize: 3528
|
|
// CHECK-NEXT: Flags [ (0x4)
|
|
// CHECK-NEXT: PF_R (0x4)
|
|
// CHECK-NEXT: ]
|
|
// CHECK-NEXT: Alignment: 1
|
|
// CHECK-NEXT: }
|
|
// CHECK-NEXT: ProgramHeader {
|
|
// CHECK-NEXT: Type: PT_GNU_STACK (0x6474E551)
|
|
// CHECK-NEXT: Offset: 0x0
|
|
// CHECK-NEXT: VirtualAddress: 0x0
|
|
// CHECK-NEXT: PhysicalAddress: 0x0
|
|
// CHECK-NEXT: FileSize: 0
|
|
// CHECK-NEXT: MemSize: 0
|
|
// CHECK-NEXT: Flags [ (0x6)
|
|
// CHECK-NEXT: PF_R (0x4)
|
|
// CHECK-NEXT: PF_W (0x2)
|
|
// CHECK-NEXT: ]
|
|
// CHECK-NEXT: Alignment: 0
|
|
// CHECK-NEXT: }
|
|
// CHECK-NEXT:]
|