Home | History | Annotate | Download | only in Sparc
      1 ! RUN: llvm-mc %s -arch=sparcv9 --relocation-model=pic -filetype=obj | llvm-readobj -r | FileCheck %s
      2 
      3 
      4 ! CHECK:      Relocations [
      5 ! CHECK-NOT:    0x{{[0-9,A-F]+}} R_SPARC_WPLT30 .text 0xC
      6 ! CHECK:        0x{{[0-9,A-F]+}} R_SPARC_PC22 _GLOBAL_OFFSET_TABLE_ 0x4
      7 ! CHECK-NEXT:   0x{{[0-9,A-F]+}} R_SPARC_PC10 _GLOBAL_OFFSET_TABLE_ 0x8
      8 ! CHECK-NEXT:   0x{{[0-9,A-F]+}} R_SPARC_GOT22 AGlobalVar 0x0
      9 ! CHECK-NEXT:   0x{{[0-9,A-F]+}} R_SPARC_GOT10 AGlobalVar 0x0
     10 ! CHECK-NEXT:   0x{{[0-9,A-F]+}} R_SPARC_WPLT30 bar 0x0
     11 ! CHECK:      ]
     12 
     13         .text
     14         .globl  foo
     15         .align  4
     16         .type   foo,@function
     17 foo:
     18         .cfi_startproc
     19         save %sp, -176, %sp
     20         .cfi_def_cfa_register %fp
     21         .cfi_window_save
     22         .cfi_register 15, 31
     23 .Ltmp4:
     24         call .Ltmp5
     25 .Ltmp6:
     26         sethi %hi(_GLOBAL_OFFSET_TABLE_+(.Ltmp6-.Ltmp4)), %i1
     27 .Ltmp5:
     28         or %i1, %lo(_GLOBAL_OFFSET_TABLE_+(.Ltmp5-.Ltmp4)), %i1
     29         add %i1, %o7, %i1
     30         sethi %hi(AGlobalVar), %i2
     31         add %i2, %lo(AGlobalVar), %i2
     32         ldx [%i1+%i2], %i1
     33         ldx [%i1], %i1
     34         call bar
     35         add %i0, %i1, %o0
     36         ret
     37         restore %g0, %o0, %o0
     38 .Ltmp7:
     39         .size   foo, .Ltmp7-foo
     40         .cfi_endproc
     41 
     42         .type   AGlobalVar,@object      ! @AGlobalVar
     43         .section        .bss,#alloc,#write
     44         .globl  AGlobalVar
     45         .align  8
     46 AGlobalVar:
     47         .xword  0                       ! 0x0
     48         .size   AGlobalVar, 8
     49 
     50