# Check position of PT_MIPS_REGINFO segment. # It should go right after the PT_INTERP segment. # RUN: yaml2obj -format=elf %s > %t.o # RUN: lld -flavor old-gnu -target mipsel -e T0 -o %t.exe %t.o # RUN: llvm-readobj -program-headers %t.exe | FileCheck %s # CHECK: ProgramHeader { # CHECK: Type: PT_INTERP # CHECK-NEXT: Offset: 0x{{[0-9A-F]+}} # CHECK-NEXT: VirtualAddress: 0x{{[0-9A-F]+}} # CHECK-NEXT: PhysicalAddress: 0x{{[0-9A-F]+}} # CHECK-NEXT: FileSize: 13 # CHECK-NEXT: MemSize: 13 # CHECK-NEXT: Flags [ # CHECK-NEXT: PF_R # CHECK-NEXT: ] # CHECK-NEXT: Alignment: 1 # CHECK-NEXT: } # CHECK-NEXT: ProgramHeader { # CHECK-NEXT: Type: PT_MIPS_REGINFO # CHECK-NEXT: Offset: 0x{{[0-9A-F]+}} # CHECK-NEXT: VirtualAddress: 0x{{[0-9A-F]+}} # CHECK-NEXT: PhysicalAddress: 0x{{[0-9A-F]+}} # CHECK-NEXT: FileSize: 24 # CHECK-NEXT: MemSize: 24 # CHECK-NEXT: Flags [ # CHECK-NEXT: PF_R # CHECK-NEXT: ] # CHECK-NEXT: Alignment: 4 # CHECK-NEXT: } FileHeader: Class: ELFCLASS32 Data: ELFDATA2LSB Type: ET_REL Machine: EM_MIPS Flags: [EF_MIPS_PIC, EF_MIPS_CPIC, EF_MIPS_ABI_O32, EF_MIPS_ARCH_32R2] Sections: - Name: .text Type: SHT_PROGBITS Flags: [ SHF_ALLOC, SHF_EXECINSTR ] Size: 4 AddressAlign: 16 - Name: .reginfo Type: SHT_MIPS_REGINFO Flags: [ SHF_ALLOC ] AddressAlign: 4 Content: "F0000000E0000000D0000000C0000000B000000000100000" Symbols: Global: - Name: T0 Section: .text Type: STT_FUNC Value: 0 Size: 4