blob: 40e95672b3be242c4d8b538c39ffac783a86d13a [file] [log] [blame]
Jordan Rupprechtcf676332018-08-17 18:51:11 +00001# RUN: echo abcd > %t.txt
2
3# RUN: llvm-objcopy -I binary -B aarch64 %t.txt %t.aarch64.o
Jordan Rupprecht2b329022019-04-18 14:22:37 +00004# RUN: llvm-readobj --file-headers %t.aarch64.o | FileCheck %s --check-prefixes=CHECK,LE,AARCH64,64
Jordan Rupprechtcf676332018-08-17 18:51:11 +00005
6# RUN: llvm-objcopy -I binary -B arm %t.txt %t.arm.o
Jordan Rupprecht2b329022019-04-18 14:22:37 +00007# RUN: llvm-readobj --file-headers %t.arm.o | FileCheck %s --check-prefixes=CHECK,LE,ARM,32
Jordan Rupprechtcf676332018-08-17 18:51:11 +00008
9# RUN: llvm-objcopy -I binary -B i386 %t.txt %t.i386.o
Jordan Rupprecht2b329022019-04-18 14:22:37 +000010# RUN: llvm-readobj --file-headers %t.i386.o | FileCheck %s --check-prefixes=CHECK,LE,I386,32
Jordan Rupprechtcf676332018-08-17 18:51:11 +000011
Jordan Rupprechtbb179a12018-08-17 19:18:20 +000012# RUN: llvm-objcopy -I binary -B i386:x86-64 %t.txt %t.i386_x86-64.o
Jordan Rupprecht2b329022019-04-18 14:22:37 +000013# RUN: llvm-readobj --file-headers %t.i386_x86-64.o | FileCheck %s --check-prefixes=CHECK,LE,X86-64,64
14
15# RUN: llvm-objcopy -I binary -B mips %t.txt %t.mips.o
16# RUN: llvm-readobj --file-headers %t.mips.o | FileCheck %s --check-prefixes=CHECK,BE,MIPS,32
Jordan Rupprechtcf676332018-08-17 18:51:11 +000017
Jordan Rupprechtbb179a12018-08-17 19:18:20 +000018# RUN: llvm-objcopy -I binary -B powerpc:common64 %t.txt %t.powerpc_common64.o
Jordan Rupprecht2b329022019-04-18 14:22:37 +000019# RUN: llvm-readobj --file-headers %t.powerpc_common64.o | FileCheck %s --check-prefixes=CHECK,LE,PPC,64
Jordan Rupprechtcf676332018-08-17 18:51:11 +000020
Jordan Rupprecht96bbb1d2019-04-30 15:21:36 +000021# RUN: llvm-objcopy -I binary -B riscv:rv32 %t.txt %t.rv32.o
22# RUN: llvm-readobj --file-headers %t.rv32.o | FileCheck %s --check-prefixes=CHECK,LE,RISCV32,32
23
24# RUN: llvm-objcopy -I binary -B riscv:rv64 %t.txt %t.rv64.o
25# RUN: llvm-readobj --file-headers %t.rv64.o | FileCheck %s --check-prefixes=CHECK,LE,RISCV64,64
26
Jordan Rupprechtcf676332018-08-17 18:51:11 +000027# RUN: llvm-objcopy -I binary -B sparc %t.txt %t.sparc.o
Jordan Rupprecht2b329022019-04-18 14:22:37 +000028# RUN: llvm-readobj --file-headers %t.sparc.o | FileCheck %s --check-prefixes=CHECK,LE,SPARC,32
Jordan Rupprechtcf676332018-08-17 18:51:11 +000029
30# RUN: llvm-objcopy -I binary -B x86-64 %t.txt %t.x86-64.o
Jordan Rupprecht2b329022019-04-18 14:22:37 +000031# RUN: llvm-readobj --file-headers %t.x86-64.o | FileCheck %s --check-prefixes=CHECK,LE,X86-64,64
Jordan Rupprechtcf676332018-08-17 18:51:11 +000032
33# CHECK: Format:
Jordan Rupprecht96bbb1d2019-04-30 15:21:36 +000034# 32-SAME: ELF32-
35# 64-SAME: ELF64-
36# AARCH64-SAME: aarch64-little
37# ARM-SAME: arm-little
38# I386-SAME: i386
39# MIPS-SAME: mips{{$}}
40# RISCV32-SAME: riscv{{$}}
41# RISCV64-SAME: riscv{{$}}
42# PPC-SAME: ppc64
43# SPARC-SAME: sparc
44# X86-64-SAME: x86-64
Jordan Rupprechtcf676332018-08-17 18:51:11 +000045
46# AARCH64-NEXT: Arch: aarch64
47# ARM-NEXT: Arch: arm
48# I386-NEXT: Arch: i386
Jordan Rupprecht2b329022019-04-18 14:22:37 +000049# MIPS-NEXT: Arch: mips{{$$}}
Jordan Rupprechtcf676332018-08-17 18:51:11 +000050# PPC-NEXT: Arch: powerpc64le
Jordan Rupprecht96bbb1d2019-04-30 15:21:36 +000051# RISCV32-NEXT: Arch: riscv32
52# RISCV64-NEXT: Arch: riscv64
Jordan Rupprechtcf676332018-08-17 18:51:11 +000053# SPARC-NEXT: Arch: sparcel
54# X86-64-NEXT: Arch: x86_64
55
56# 32-NEXT: AddressSize: 32bit
57# 64-NEXT: AddressSize: 64bit
58
59# CHECK: ElfHeader {
60# CHECK-NEXT: Ident {
61# CHECK-NEXT: Magic: (7F 45 4C 46)
62# 32-NEXT: Class: 32-bit (0x1)
63# 64-NEXT: Class: 64-bit (0x2)
Jordan Rupprecht2b329022019-04-18 14:22:37 +000064# LE-NEXT: DataEncoding: LittleEndian (0x1)
65# BE-NEXT: DataEncoding: BigEndian (0x2)
Jordan Rupprechtcf676332018-08-17 18:51:11 +000066# CHECK-NEXT: FileVersion: 1
67# CHECK-NEXT: OS/ABI: SystemV (0x0)
68# CHECK-NEXT: ABIVersion: 0
69# CHECK-NEXT: Unused: (00 00 00 00 00 00 00)
70# CHECK-NEXT: }
71# CHECK-NEXT: Type: Relocatable (0x1)
72# AARCH64-NEXT: Machine: EM_AARCH64 (0xB7)
73# ARM-NEXT: Machine: EM_ARM (0x28)
74# I386-NEXT: Machine: EM_386 (0x3)
Jordan Rupprecht2b329022019-04-18 14:22:37 +000075# MIPS-NEXT: Machine: EM_MIPS (0x8)
Jordan Rupprechtcf676332018-08-17 18:51:11 +000076# PPC-NEXT: Machine: EM_PPC64 (0x15)
Jordan Rupprecht96bbb1d2019-04-30 15:21:36 +000077# RISCV32-NEXT: Machine: EM_RISCV (0xF3)
78# RISCV64-NEXT: Machine: EM_RISCV (0xF3)
Jordan Rupprechtcf676332018-08-17 18:51:11 +000079# SPARC-NEXT: Machine: EM_SPARC (0x2)
80# X86-64-NEXT: Machine: EM_X86_64 (0x3E)
81# CHECK-NEXT: Version: 1
82# CHECK-NEXT: Entry: 0x0
83# CHECK-NEXT: ProgramHeaderOffset:
84# CHECK-NEXT: SectionHeaderOffset:
85# CHECK-NEXT: Flags [ (0x0)
86# CHECK-NEXT: ]
87# 32-NEXT: HeaderSize: 52
88# 64-NEXT: HeaderSize: 64
Julie Hockett468722e2018-09-12 17:56:31 +000089# 32-NEXT: ProgramHeaderEntrySize: 0
90# 64-NEXT: ProgramHeaderEntrySize: 0
Jordan Rupprechtcf676332018-08-17 18:51:11 +000091# CHECK-NEXT: ProgramHeaderCount: 0
92# 32-NEXT: SectionHeaderEntrySize: 40
93# 64-NEXT: SectionHeaderEntrySize: 64
94# CHECK-NEXT: SectionHeaderCount: 4
95# CHECK-NEXT: StringTableSectionIndex:
96# CHECK-NEXT: }