File: emulation-riscv.s

package info (click to toggle)
llvm-toolchain-9 1%3A9.0.1-16
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 882,436 kB
  • sloc: cpp: 4,167,636; ansic: 714,256; asm: 457,610; python: 155,927; objc: 65,094; sh: 42,856; lisp: 26,908; perl: 7,786; pascal: 7,722; makefile: 6,881; ml: 5,581; awk: 3,648; cs: 2,027; xml: 888; javascript: 381; ruby: 156
file content (74 lines) | stat: -rw-r--r-- 2,569 bytes parent folder | download | duplicates (32)
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
65
66
67
68
69
70
71
72
73
74
# REQUIRES: riscv

# RUN: llvm-mc -filetype=obj -triple=riscv32 %s -o %t.o
# RUN: ld.lld %t.o -o %t
# RUN: llvm-readobj --file-headers %t | FileCheck --check-prefix=RV32 %s
# RUN: ld.lld -m elf32lriscv %t.o -o %t
# RUN: llvm-readobj --file-headers %t | FileCheck --check-prefix=RV32 %s
# RUN: echo 'OUTPUT_FORMAT(elf32-littleriscv)' > %t.script
# RUN: ld.lld %t.script %t.o -o %t
# RUN: llvm-readobj --file-headers %t | FileCheck --check-prefix=RV32 %s

# RV32:      ElfHeader {
# RV32-NEXT:   Ident {
# RV32-NEXT:     Magic: (7F 45 4C 46)
# RV32-NEXT:     Class: 32-bit (0x1)
# RV32-NEXT:     DataEncoding: LittleEndian (0x1)
# RV32-NEXT:     FileVersion: 1
# RV32-NEXT:     OS/ABI: SystemV (0x0)
# RV32-NEXT:     ABIVersion: 0
# RV32-NEXT:     Unused: (00 00 00 00 00 00 00)
# RV32-NEXT:   }
# RV32-NEXT:   Type: Executable (0x2)
# RV32-NEXT:   Machine: EM_RISCV (0xF3)
# RV32-NEXT:   Version: 1
# RV32-NEXT:   Entry:
# RV32-NEXT:   ProgramHeaderOffset: 0x34
# RV32-NEXT:   SectionHeaderOffset:
# RV32-NEXT:   Flags [ (0x0)
# RV32-NEXT:   ]
# RV32-NEXT:   HeaderSize: 52
# RV32-NEXT:   ProgramHeaderEntrySize: 32
# RV32-NEXT:   ProgramHeaderCount:
# RV32-NEXT:   SectionHeaderEntrySize: 40
# RV32-NEXT:   SectionHeaderCount:
# RV32-NEXT:   StringTableSectionIndex:
# RV32-NEXT: }

# RUN: llvm-mc -filetype=obj -triple=riscv64 %s -o %t.o
# RUN: ld.lld %t.o -o %t
# RUN: llvm-readobj --file-headers %t | FileCheck --check-prefix=RV64 %s
# RUN: ld.lld -m elf64lriscv %t.o -o %t
# RUN: llvm-readobj --file-headers %t | FileCheck --check-prefix=RV64 %s
# RUN: echo 'OUTPUT_FORMAT(elf64-littleriscv)' > %t.script
# RUN: ld.lld %t.script %t.o -o %t
# RUN: llvm-readobj --file-headers %t | FileCheck --check-prefix=RV64 %s

# RV64:      ElfHeader {
# RV64-NEXT:   Ident {
# RV64-NEXT:     Magic: (7F 45 4C 46)
# RV64-NEXT:     Class: 64-bit (0x2)
# RV64-NEXT:     DataEncoding: LittleEndian (0x1)
# RV64-NEXT:     FileVersion: 1
# RV64-NEXT:     OS/ABI: SystemV (0x0)
# RV64-NEXT:     ABIVersion: 0
# RV64-NEXT:     Unused: (00 00 00 00 00 00 00)
# RV64-NEXT:   }
# RV64-NEXT:   Type: Executable (0x2)
# RV64-NEXT:   Machine: EM_RISCV (0xF3)
# RV64-NEXT:   Version: 1
# RV64-NEXT:   Entry:
# RV64-NEXT:   ProgramHeaderOffset: 0x40
# RV64-NEXT:   SectionHeaderOffset:
# RV64-NEXT:   Flags [ (0x0)
# RV64-NEXT:   ]
# RV64-NEXT:   HeaderSize: 64
# RV64-NEXT:   ProgramHeaderEntrySize: 56
# RV64-NEXT:   ProgramHeaderCount:
# RV64-NEXT:   SectionHeaderEntrySize: 64
# RV64-NEXT:   SectionHeaderCount:
# RV64-NEXT:   StringTableSectionIndex:
# RV64-NEXT: }

.globl _start
_start: