1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64
|
## Check llvm-readobj is able to decode all possible LoongArch e_flags field values.
# RUN: yaml2obj %s -o %t-lp64s -DCLASS=64 -DFLAG=LP64S
# RUN: llvm-readobj -h %t-lp64s | FileCheck --check-prefix=READOBJ-LP64S %s
# RUN: llvm-readelf -h %t-lp64s | FileCheck --check-prefix=READELF-LP64S --match-full-lines %s
# RUN: yaml2obj %s -o %t-lp64f -DCLASS=64 -DFLAG=LP64F
# RUN: llvm-readobj -h %t-lp64f | FileCheck --check-prefix=READOBJ-LP64F %s
# RUN: llvm-readelf -h %t-lp64f | FileCheck --check-prefix=READELF-LP64F --match-full-lines %s
# RUN: yaml2obj %s -o %t-lp64d -DCLASS=64 -DFLAG=LP64D
# RUN: llvm-readobj -h %t-lp64d | FileCheck --check-prefix=READOBJ-LP64D %s
# RUN: llvm-readelf -h %t-lp64d | FileCheck --check-prefix=READELF-LP64D --match-full-lines %s
# RUN: yaml2obj %s -o %t-ilp32s -DCLASS=32 -DFLAG=ILP32S
# RUN: llvm-readobj -h %t-ilp32s | FileCheck --check-prefix=READOBJ-ILP32S %s
# RUN: llvm-readelf -h %t-ilp32s | FileCheck --check-prefix=READELF-ILP32S --match-full-lines %s
# RUN: yaml2obj %s -o %t-ilp32f -DCLASS=32 -DFLAG=ILP32F
# RUN: llvm-readobj -h %t-ilp32f | FileCheck --check-prefix=READOBJ-ILP32F %s
# RUN: llvm-readelf -h %t-ilp32f | FileCheck --check-prefix=READELF-ILP32F --match-full-lines %s
# RUN: yaml2obj %s -o %t-ilp32d -DCLASS=32 -DFLAG=ILP32D
# RUN: llvm-readobj -h %t-ilp32d | FileCheck --check-prefix=READOBJ-ILP32D %s
# RUN: llvm-readelf -h %t-ilp32d | FileCheck --check-prefix=READELF-ILP32D --match-full-lines %s
# READOBJ-LP64S: Flags [ (0x1)
# READOBJ-LP64S-NEXT: EF_LOONGARCH_BASE_ABI_LP64S (0x1)
# READOBJ-LP64S-NEXT: ]
# READOBJ-LP64F: Flags [ (0x2)
# READOBJ-LP64F-NEXT: EF_LOONGARCH_BASE_ABI_LP64F (0x2)
# READOBJ-LP64F-NEXT: ]
# READOBJ-LP64D: Flags [ (0x3)
# READOBJ-LP64D-NEXT: EF_LOONGARCH_BASE_ABI_LP64D (0x3)
# READOBJ-LP64D-NEXT: ]
# READOBJ-ILP32S: Flags [ (0x5)
# READOBJ-ILP32S-NEXT: EF_LOONGARCH_BASE_ABI_ILP32S (0x5)
# READOBJ-ILP32S-NEXT: ]
# READOBJ-ILP32F: Flags [ (0x6)
# READOBJ-ILP32F-NEXT: EF_LOONGARCH_BASE_ABI_ILP32F (0x6)
# READOBJ-ILP32F-NEXT: ]
# READOBJ-ILP32D: Flags [ (0x7)
# READOBJ-ILP32D-NEXT: EF_LOONGARCH_BASE_ABI_ILP32D (0x7)
# READOBJ-ILP32D-NEXT: ]
# READELF-LP64S: Flags: 0x1, LP64, SOFT-FLOAT
# READELF-LP64F: Flags: 0x2, LP64, SINGLE-FLOAT
# READELF-LP64D: Flags: 0x3, LP64, DOUBLE-FLOAT
# READELF-ILP32S: Flags: 0x5, ILP32, SOFT-FLOAT
# READELF-ILP32F: Flags: 0x6, ILP32, SINGLE-FLOAT
# READELF-ILP32D: Flags: 0x7, ILP32, DOUBLE-FLOAT
--- !ELF
FileHeader:
Class: ELFCLASS[[CLASS]]
Data: ELFDATA2LSB
Type: ET_EXEC
Machine: EM_LOONGARCH
Flags: [ EF_LOONGARCH_BASE_ABI_[[FLAG]] ]
|