summaryrefslogtreecommitdiff
path: root/test/MC/Mips/elf-gprel-32-64.ll
blob: b94682214df765c73e202e343eb8faa83022cd98 (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
37
; RUN: llc -filetype=obj -march=mips64el -mcpu=mips64 %s -o - \
; RUN: | elf-dump --dump-section-data \
; RUN: | FileCheck %s

define i32 @test(i32 %c) nounwind {
entry:
  switch i32 %c, label %sw.default [
    i32 0, label %sw.bb
    i32 1, label %sw.bb2
    i32 2, label %sw.bb5
    i32 3, label %sw.bb8
  ]

sw.bb:
  br label %return
sw.bb2:
  br label %return
sw.bb5:
  br label %return
sw.bb8:
  br label %return
sw.default:
  br label %return

return:
  %retval.0 = phi i32 [ -1, %sw.default ], [ 7, %sw.bb8 ], [ 2, %sw.bb5 ], [ 3, %sw.bb2 ], [ 1, %sw.bb ]
  ret i32 %retval.0
}

; Check that the appropriate relocations were created.

; R_MIPS_GPREL32/R_MIPS_64/R_MIPS_NONE
; CHECK: (('sh_name', 0x{{[a-z0-9]+}}) # '.rela.rodata'
; CHECK:      ('r_type3', 0x00)
; CHECK-NEXT: ('r_type2', 0x12)
; CHECK-NEXT: ('r_type', 0x0c)