Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / lld / test / ELF / mips-gp-lowest.s
blob699684119bfde4c4086b0d1e0b510fcfefe1035a
1 # REQUIRES: mips
2 # Check that default _gp value is calculated relative
3 # to the GP-relative section with the lowest address.
5 # RUN: llvm-mc -filetype=obj -triple=mips-unknown-linux %s -o %t.o
6 # RUN: echo "SECTIONS { \
7 # RUN: .sdata : { *(.sdata) } \
8 # RUN: .got : { *(.got) } }" > %t.rel.script
9 # RUN: ld.lld %t.o --script %t.rel.script -shared -o %t.so
10 # RUN: llvm-readobj -S --symbols %t.so | FileCheck %s
12 .text
13 .global foo
14 foo:
15 lui $gp, %call16(foo)
17 .sdata
18 .word 0
20 # CHECK: Section {
21 # CHECK: Name: .sdata
22 # CHECK-NEXT: Type: SHT_PROGBITS
23 # CHECK-NEXT: Flags [
24 # CHECK-NEXT: SHF_ALLOC
25 # CHECK-NEXT: SHF_MIPS_GPREL
26 # CHECK-NEXT: SHF_WRITE
27 # CHECK-NEXT: ]
28 # CHECK-NEXT: Address: 0xF0
29 # CHECK: }
30 # CHECK: Section {
31 # CHECK: Name: .got
32 # CHECK-NEXT: Type: SHT_PROGBITS
33 # CHECK-NEXT: Flags [
34 # CHECK-NEXT: SHF_ALLOC
35 # CHECK-NEXT: SHF_MIPS_GPREL
36 # CHECK-NEXT: SHF_WRITE
37 # CHECK-NEXT: ]
38 # CHECK-NEXT: Address: 0x100
39 # CHECK: }
41 # CHECK: Name: _gp (5)
42 # CHECK-NEXT: Value: 0x80E0
43 # ^-- 0xF0 + 0x7ff0