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
# REQUIRES: mips
# Check R_MIPS_32 relocation calculation.

# RUN: echo "SECTIONS { \
# RUN:         . = 0x10000; .data ALIGN(0x1000) : { *(.data) } \
# RUN:       }" > %t.script

# RUN: llvm-mc -filetype=obj -triple=mips-unknown-linux %s -o %t-be.o
# RUN: ld.lld -shared %t-be.o -script %t.script -o %t-be.so
# RUN: llvm-objdump -t -s %t-be.so | FileCheck -check-prefixes=SYM,BE %s
# RUN: llvm-readelf -r -s --dynamic-table -A %t-be.so \
# RUN:   | FileCheck -check-prefix=REL %s

# RUN: llvm-mc -filetype=obj -triple=mipsel-unknown-linux %s -o %t-el.o
# RUN: ld.lld -shared %t-el.o -script %t.script -o %t-el.so
# RUN: llvm-objdump -t -s %t-el.so | FileCheck -check-prefixes=SYM,EL %s
# RUN: llvm-readelf -r -s --dynamic-table -A %t-el.so \
# RUN:   | FileCheck -check-prefix=REL %s

  .data
  .globl v2
v1:
  .word v2+4 # R_MIPS_32 target v2 addend 4
v2:
  .word v1   # R_MIPS_32 target v1 addend 0

# SYM: SYMBOL TABLE:
# SYM: 00011000  .data  00000000 v1

# BE: Contents of section .data:
# BE-NEXT: {{.*}} 00000004 00011000
#                 ^-- v2+4 ^-- v1

# EL: Contents of section .data:
# EL-NEXT: {{.*}} 04000000 00100100
#                 ^-- v2+4 ^-- v1
# REL: Relocation section
# REL:      {{.*}} R_MIPS_REL32
# REL-NEXT: {{.*}} R_MIPS_REL32 [[V2:[0-9a-f]+]]

# REL: Symbol table
# REL: {{.*}}: [[V2]] {{.*}} v2

# REL: Dynamic section
# REL:     (RELSZ)    16
# REL:     (RELENT)    8
# REL-NOT: (RELCOUNT)

# REL: Global entries
# REL: {{.*}} -32744(gp) [[V2]] {{.*}} v2