xref: /aosp_15_r20/external/llvm/test/MC/Sparc/sparc-pic.s (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker! RUN: llvm-mc %s -arch=sparcv9 --position-independent -filetype=obj | llvm-readobj -r | FileCheck --check-prefix=PIC %s
2*9880d681SAndroid Build Coastguard Worker! RUN: llvm-mc %s -arch=sparcv9 -filetype=obj | llvm-readobj -r | FileCheck --check-prefix=NOPIC %s
3*9880d681SAndroid Build Coastguard Worker
4*9880d681SAndroid Build Coastguard Worker
5*9880d681SAndroid Build Coastguard Worker! PIC:      Relocations [
6*9880d681SAndroid Build Coastguard Worker! PIC-NOT:    0x{{[0-9,A-F]+}} R_SPARC_WPLT30 .text 0xC
7*9880d681SAndroid Build Coastguard Worker! PIC:        0x{{[0-9,A-F]+}} R_SPARC_PC22 _GLOBAL_OFFSET_TABLE_ 0x4
8*9880d681SAndroid Build Coastguard Worker! PIC-NEXT:   0x{{[0-9,A-F]+}} R_SPARC_PC10 _GLOBAL_OFFSET_TABLE_ 0x8
9*9880d681SAndroid Build Coastguard Worker! PIC-NEXT:   0x{{[0-9,A-F]+}} R_SPARC_PC22 _GLOBAL_OFFSET_TABLE_ 0x0
10*9880d681SAndroid Build Coastguard Worker! PIC-NEXT:   0x{{[0-9,A-F]+}} R_SPARC_PC10 _GLOBAL_OFFSET_TABLE_ 0x0
11*9880d681SAndroid Build Coastguard Worker! PIC-NEXT:   0x{{[0-9,A-F]+}} R_SPARC_GOT22 AGlobalVar 0x0
12*9880d681SAndroid Build Coastguard Worker! PIC-NEXT:   0x{{[0-9,A-F]+}} R_SPARC_GOT10 AGlobalVar 0x0
13*9880d681SAndroid Build Coastguard Worker! PIC-NEXT:   0x{{[0-9,A-F]+}} R_SPARC_GOT22 AGlobalVar 0x0
14*9880d681SAndroid Build Coastguard Worker! PIC-NEXT:   0x{{[0-9,A-F]+}} R_SPARC_GOT10 AGlobalVar 0x0
15*9880d681SAndroid Build Coastguard Worker! PIC-NEXT:   0x{{[0-9,A-F]+}} R_SPARC_GOT22 .LC0 0x0
16*9880d681SAndroid Build Coastguard Worker! PIC-NEXT:   0x{{[0-9,A-F]+}} R_SPARC_GOT10 .LC0 0x0
17*9880d681SAndroid Build Coastguard Worker! PIC-NEXT:   0x{{[0-9,A-F]+}} R_SPARC_WPLT30 bar 0x0
18*9880d681SAndroid Build Coastguard Worker! PIC:      ]
19*9880d681SAndroid Build Coastguard Worker
20*9880d681SAndroid Build Coastguard Worker! NOPIC:      Relocations [
21*9880d681SAndroid Build Coastguard Worker! NOPIC-NOT:    0x{{[0-9,A-F]+}} R_SPARC_WPLT30 .text 0xC
22*9880d681SAndroid Build Coastguard Worker! NOPIC:        0x{{[0-9,A-F]+}} R_SPARC_HI22 _GLOBAL_OFFSET_TABLE_ 0x4
23*9880d681SAndroid Build Coastguard Worker! NOPIC-NEXT:   0x{{[0-9,A-F]+}} R_SPARC_LO10 _GLOBAL_OFFSET_TABLE_ 0x8
24*9880d681SAndroid Build Coastguard Worker! NOPIC-NEXT:   0x{{[0-9,A-F]+}} R_SPARC_HI22 _GLOBAL_OFFSET_TABLE_ 0x0
25*9880d681SAndroid Build Coastguard Worker! NOPIC-NEXT:   0x{{[0-9,A-F]+}} R_SPARC_LO10 _GLOBAL_OFFSET_TABLE_ 0x0
26*9880d681SAndroid Build Coastguard Worker! NOPIC-NEXT:   0x{{[0-9,A-F]+}} R_SPARC_HI22 AGlobalVar 0x0
27*9880d681SAndroid Build Coastguard Worker! NOPIC-NEXT:   0x{{[0-9,A-F]+}} R_SPARC_LO10 AGlobalVar 0x0
28*9880d681SAndroid Build Coastguard Worker! NOPIC-NEXT:   0x{{[0-9,A-F]+}} R_SPARC_HI22 AGlobalVar 0x0
29*9880d681SAndroid Build Coastguard Worker! NOPIC-NEXT:   0x{{[0-9,A-F]+}} R_SPARC_LO10 AGlobalVar 0x0
30*9880d681SAndroid Build Coastguard Worker! NOPIC-NEXT:   0x{{[0-9,A-F]+}} R_SPARC_HI22 .rodata 0x0
31*9880d681SAndroid Build Coastguard Worker! NOPIC-NEXT:   0x{{[0-9,A-F]+}} R_SPARC_LO10 .rodata 0x0
32*9880d681SAndroid Build Coastguard Worker! NOPIC-NEXT:   0x{{[0-9,A-F]+}} R_SPARC_WDISP30 bar 0x0
33*9880d681SAndroid Build Coastguard Worker! NOPIC:      ]
34*9880d681SAndroid Build Coastguard Worker
35*9880d681SAndroid Build Coastguard Worker        .section        ".rodata"
36*9880d681SAndroid Build Coastguard Worker        .align 8
37*9880d681SAndroid Build Coastguard Worker.LC0:
38*9880d681SAndroid Build Coastguard Worker        .asciz   "string"
39*9880d681SAndroid Build Coastguard Worker        .section ".text"
40*9880d681SAndroid Build Coastguard Worker        .text
41*9880d681SAndroid Build Coastguard Worker        .globl  foo
42*9880d681SAndroid Build Coastguard Worker        .align  4
43*9880d681SAndroid Build Coastguard Worker        .type   foo,@function
44*9880d681SAndroid Build Coastguard Workerfoo:
45*9880d681SAndroid Build Coastguard Worker        .cfi_startproc
46*9880d681SAndroid Build Coastguard Worker        save %sp, -176, %sp
47*9880d681SAndroid Build Coastguard Worker        .cfi_def_cfa_register %fp
48*9880d681SAndroid Build Coastguard Worker        .cfi_window_save
49*9880d681SAndroid Build Coastguard Worker        .cfi_register 15, 31
50*9880d681SAndroid Build Coastguard Worker.Ltmp4:
51*9880d681SAndroid Build Coastguard Worker        call .Ltmp5
52*9880d681SAndroid Build Coastguard Worker.Ltmp6:
53*9880d681SAndroid Build Coastguard Worker        sethi %hi(_GLOBAL_OFFSET_TABLE_+(.Ltmp6-.Ltmp4)), %i1
54*9880d681SAndroid Build Coastguard Worker.Ltmp5:
55*9880d681SAndroid Build Coastguard Worker        or %i1, %lo(_GLOBAL_OFFSET_TABLE_+(.Ltmp5-.Ltmp4)), %i1
56*9880d681SAndroid Build Coastguard Worker        set _GLOBAL_OFFSET_TABLE_, %i1
57*9880d681SAndroid Build Coastguard Worker        add %i1, %o7, %i1
58*9880d681SAndroid Build Coastguard Worker        sethi %hi(AGlobalVar), %i2
59*9880d681SAndroid Build Coastguard Worker        add %i2, %lo(AGlobalVar), %i2
60*9880d681SAndroid Build Coastguard Worker        set AGlobalVar, %i2
61*9880d681SAndroid Build Coastguard Worker        ldx [%i1+%i2], %i3
62*9880d681SAndroid Build Coastguard Worker        ldx [%i3], %i3
63*9880d681SAndroid Build Coastguard Worker        sethi %hi(.LC0), %i2
64*9880d681SAndroid Build Coastguard Worker        add %i2, %lo(.LC0), %i2
65*9880d681SAndroid Build Coastguard Worker        ldx [%i1+%i2], %i4
66*9880d681SAndroid Build Coastguard Worker        call bar
67*9880d681SAndroid Build Coastguard Worker        add %i0, %i1, %o0
68*9880d681SAndroid Build Coastguard Worker        ret
69*9880d681SAndroid Build Coastguard Worker        restore %g0, %o0, %o0
70*9880d681SAndroid Build Coastguard Worker.Ltmp7:
71*9880d681SAndroid Build Coastguard Worker        .size   foo, .Ltmp7-foo
72*9880d681SAndroid Build Coastguard Worker        .cfi_endproc
73*9880d681SAndroid Build Coastguard Worker
74*9880d681SAndroid Build Coastguard Worker        .type   AGlobalVar,@object      ! @AGlobalVar
75*9880d681SAndroid Build Coastguard Worker        .section        .bss,#alloc,#write
76*9880d681SAndroid Build Coastguard Worker        .globl  AGlobalVar
77*9880d681SAndroid Build Coastguard Worker        .align  8
78*9880d681SAndroid Build Coastguard WorkerAGlobalVar:
79*9880d681SAndroid Build Coastguard Worker        .xword  0                       ! 0x0
80*9880d681SAndroid Build Coastguard Worker        .size   AGlobalVar, 8
81