reference, declarationdefinition
definition → references, declarations, derived classes, virtual overrides
reference to multiple definitions → definitions
unreferenced
    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: