# Check that LLD set ABIVersion to '3' if it generates executable # file with FP_64 / FP_64A floating point abi flags. # RUN: yaml2obj -format=elf %s > %t.o # RUN: lld -flavor gnu -target mipsel -e T0 -o %t.exe %t.o # RUN: llvm-readobj -file-headers %t.exe | FileCheck %s # CHECK: Format: ELF32-mips # CHECK: Arch: mipsel # CHECK: AddressSize: 32bit # CHECK: LoadName: # CHECK: ElfHeader { # CHECK: Ident { # CHECK: Magic: (7F 45 4C 46) # CHECK: Class: 32-bit (0x1) # CHECK: DataEncoding: LittleEndian (0x1) # CHECK: FileVersion: 1 # CHECK: OS/ABI: SystemV (0x0) # CHECK: ABIVersion: 3 # CHECK: Unused: (00 00 00 00 00 00 00) # CHECK: } # CHECK: Type: Executable (0x2) # CHECK: Machine: EM_MIPS (0x8) # CHECK: Version: 1 # CHECK: Entry: 0x{{[0-9A-F]+}} # CHECK: ProgramHeaderOffset: 0x{{[0-9A-F]+}} # CHECK: SectionHeaderOffset: 0x{{[0-9A-F]+}} # CHECK: Flags [ (0x50001005) # CHECK: EF_MIPS_ABI_O32 (0x1000) # CHECK: EF_MIPS_ARCH_32 (0x50000000) # CHECK: EF_MIPS_CPIC (0x4) # CHECK: EF_MIPS_NOREORDER (0x1) # CHECK: ] # CHECK: HeaderSize: 52 # CHECK: ProgramHeaderEntrySize: 32 # CHECK: ProgramHeaderCount: {{[0-9]+}} # CHECK: SectionHeaderEntrySize: 40 # CHECK: SectionHeaderCount: {{[0-9]+}} # CHECK: StringTableSectionIndex: {{[0-9]+}} # CHECK: } # o.o --- FileHeader: Class: ELFCLASS32 Data: ELFDATA2LSB Type: ET_REL Machine: EM_MIPS Flags: [EF_MIPS_NOREORDER, EF_MIPS_CPIC, EF_MIPS_ABI_O32, EF_MIPS_ARCH_32] Sections: - Name: .text Type: SHT_PROGBITS Flags: [ SHF_ALLOC, SHF_EXECINSTR ] AddressAlign: 4 Size: 8 - Name: .MIPS.abiflags Type: SHT_MIPS_ABIFLAGS AddressAlign: 8 ISA: MIPS32 ISARevision: 1 ISAExtension: EXT_NONE FpABI: FP_64 GPRSize: REG_32 CPR1Size: REG_64 Symbols: Global: - Name: T0 Section: .text ...