Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / lld / test / ELF / emulation-riscv.s
blob7522b54d14291ba3dac7ac99850219d933696d00
1 # REQUIRES: riscv
3 # RUN: llvm-mc -filetype=obj -triple=riscv32 %s -o %t.o
4 # RUN: ld.lld %t.o -o %t
5 # RUN: llvm-readobj --file-headers %t | FileCheck --check-prefix=RV32 %s
6 # RUN: ld.lld -m elf32lriscv %t.o -o %t
7 # RUN: llvm-readobj --file-headers %t | FileCheck --check-prefix=RV32 %s
8 # RUN: echo 'OUTPUT_FORMAT(elf32-littleriscv)' > %t.script
9 # RUN: ld.lld %t.script %t.o -o %t
10 # RUN: llvm-readobj --file-headers %t | FileCheck --check-prefix=RV32 %s
12 # RV32: ElfHeader {
13 # RV32-NEXT: Ident {
14 # RV32-NEXT: Magic: (7F 45 4C 46)
15 # RV32-NEXT: Class: 32-bit (0x1)
16 # RV32-NEXT: DataEncoding: LittleEndian (0x1)
17 # RV32-NEXT: FileVersion: 1
18 # RV32-NEXT: OS/ABI: SystemV (0x0)
19 # RV32-NEXT: ABIVersion: 0
20 # RV32-NEXT: Unused: (00 00 00 00 00 00 00)
21 # RV32-NEXT: }
22 # RV32-NEXT: Type: Executable (0x2)
23 # RV32-NEXT: Machine: EM_RISCV (0xF3)
24 # RV32-NEXT: Version: 1
25 # RV32-NEXT: Entry:
26 # RV32-NEXT: ProgramHeaderOffset: 0x34
27 # RV32-NEXT: SectionHeaderOffset:
28 # RV32-NEXT: Flags [ (0x0)
29 # RV32-NEXT: ]
30 # RV32-NEXT: HeaderSize: 52
31 # RV32-NEXT: ProgramHeaderEntrySize: 32
32 # RV32-NEXT: ProgramHeaderCount:
33 # RV32-NEXT: SectionHeaderEntrySize: 40
34 # RV32-NEXT: SectionHeaderCount:
35 # RV32-NEXT: StringTableSectionIndex:
36 # RV32-NEXT: }
38 # RUN: llvm-mc -filetype=obj -triple=riscv64 %s -o %t.o
39 # RUN: ld.lld %t.o -o %t
40 # RUN: llvm-readobj --file-headers %t | FileCheck --check-prefix=RV64 %s
41 # RUN: ld.lld -m elf64lriscv %t.o -o %t
42 # RUN: llvm-readobj --file-headers %t | FileCheck --check-prefix=RV64 %s
43 # RUN: echo 'OUTPUT_FORMAT(elf64-littleriscv)' > %t.script
44 # RUN: ld.lld %t.script %t.o -o %t
45 # RUN: llvm-readobj --file-headers %t | FileCheck --check-prefix=RV64 %s
47 # RV64: ElfHeader {
48 # RV64-NEXT: Ident {
49 # RV64-NEXT: Magic: (7F 45 4C 46)
50 # RV64-NEXT: Class: 64-bit (0x2)
51 # RV64-NEXT: DataEncoding: LittleEndian (0x1)
52 # RV64-NEXT: FileVersion: 1
53 # RV64-NEXT: OS/ABI: SystemV (0x0)
54 # RV64-NEXT: ABIVersion: 0
55 # RV64-NEXT: Unused: (00 00 00 00 00 00 00)
56 # RV64-NEXT: }
57 # RV64-NEXT: Type: Executable (0x2)
58 # RV64-NEXT: Machine: EM_RISCV (0xF3)
59 # RV64-NEXT: Version: 1
60 # RV64-NEXT: Entry:
61 # RV64-NEXT: ProgramHeaderOffset: 0x40
62 # RV64-NEXT: SectionHeaderOffset:
63 # RV64-NEXT: Flags [ (0x0)
64 # RV64-NEXT: ]
65 # RV64-NEXT: HeaderSize: 64
66 # RV64-NEXT: ProgramHeaderEntrySize: 56
67 # RV64-NEXT: ProgramHeaderCount:
68 # RV64-NEXT: SectionHeaderEntrySize: 64
69 # RV64-NEXT: SectionHeaderCount:
70 # RV64-NEXT: StringTableSectionIndex:
71 # RV64-NEXT: }
73 .globl _start
74 _start: