aboutsummaryrefslogtreecommitdiff
path: root/llvm/test/tools/llvm-objcopy/ELF/mips64.test
blob: ad0cb0354cf013f84bbaab3d7c6c548b6fda3d52 (plain)
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
# mips64el has a special encoding of the r_info relocation field.
# Test that we support both endianness.

# RUN: yaml2obj %s -DENDIANNESS=ELFDATA2LSB -o %t1-le
# RUN: llvm-objcopy %t1-le %t2-le
# RUN: llvm-readobj --relocations %t2-le | FileCheck %s

# RUN: yaml2obj %s -DENDIANNESS=ELFDATA2MSB -o %t1-be
# RUN: llvm-objcopy %t1-be %t2-be
# RUN: llvm-readobj --relocations %t2-be | FileCheck %s

!ELF
FileHeader:
  Class:   ELFCLASS64
  Data:    [[ENDIANNESS]]
  Type:    ET_REL
  Machine: EM_MIPS
Sections:
  - Name: .text
    Type: SHT_PROGBITS
  - Name: .rela.text
    Type: SHT_RELA
    Relocations:
      - Offset: 8
        Symbol: foo
        Type:   R_MIPS_JALR
Symbols:
  - Name:    foo
    Type:    STT_FUNC
    Section: .text

# CHECK:      Relocations [
# CHECK-NEXT:   Section (2) .rela.text {
# CHECK-NEXT:     0x8 R_MIPS_JALR/R_MIPS_NONE/R_MIPS_NONE foo 0x0
# CHECK-NEXT:   }
# CHECK-NEXT: ]