do_switch2.s
1.64 KB
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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
// This test case will cause an internal EK_GPRel64BlockAddress to be
// produced. This was not handled for direct object and an assertion
// to occur. This is a variation on test case test/CodeGen/Mips/do_switch.ll
// RUN: llvm-mc < %s -filetype=obj -triple=mips-pc-linux
.text
.abicalls
.section .mdebug.abi32,"",@progbits
.file "/home/espindola/llvm/llvm/test/MC/Mips/do_switch.ll"
.text
.globl main
.align 2
.type main,@function
.set nomips16
.ent main
main: # @main
.frame $sp,8,$ra
.mask 0x00000000,0
.fmask 0x00000000,0
.set noreorder
.set nomacro
.set noat
# %bb.0: # %entry
lui $2, %hi(_gp_disp)
addiu $2, $2, %lo(_gp_disp)
addiu $sp, $sp, -8
addiu $1, $zero, 2
sw $1, 4($sp)
lw $3, 4($sp)
sltiu $1, $3, 4
bnez $1, $BB0_2
addu $2, $2, $25
$BB0_1: # %bb4
addiu $2, $zero, 4
jr $ra
addiu $sp, $sp, 8
$BB0_2: # %entry
sll $1, $3, 2
lw $3, %got($JTI0_0)($2)
addu $1, $1, $3
lw $1, %lo($JTI0_0)($1)
addu $1, $1, $2
jr $1
nop
$BB0_3: # %bb5
addiu $2, $zero, 1
jr $ra
addiu $sp, $sp, 8
$BB0_4: # %bb1
addiu $2, $zero, 2
jr $ra
addiu $sp, $sp, 8
$BB0_5: # %bb2
addiu $2, $zero, 0
jr $ra
addiu $sp, $sp, 8
$BB0_6: # %bb3
addiu $2, $zero, 3
jr $ra
addiu $sp, $sp, 8
.set at
.set macro
.set reorder
.end main
$tmp0:
.size main, ($tmp0)-main
.section .rodata,"a",@progbits
.align 2
$JTI0_0:
.gpword ($BB0_3)
.gpword ($BB0_4)
.gpword ($BB0_5)
.gpword ($BB0_6)
.text