2014-03-29 02:30:07 +08:00
|
|
|
// 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
|
|
|
|
|
2016-05-18 08:27:17 +08:00
|
|
|
// RUN: llvm-mc < %s -filetype=obj -triple=mips-pc-linux
|
2014-03-29 02:30:07 +08:00
|
|
|
|
|
|
|
.text
|
|
|
|
.abicalls
|
|
|
|
.option pic0
|
|
|
|
.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
|
2017-12-05 01:18:51 +08:00
|
|
|
# %bb.0: # %entry
|
2014-03-29 02:30:07 +08:00
|
|
|
addiu $sp, $sp, -8
|
|
|
|
addiu $1, $zero, 2
|
|
|
|
sw $1, 4($sp)
|
|
|
|
lw $2, 4($sp)
|
|
|
|
sltiu $1, $2, 4
|
|
|
|
bnez $1, $BB0_2
|
|
|
|
nop
|
|
|
|
$BB0_1: # %bb4
|
|
|
|
addiu $2, $zero, 4
|
|
|
|
jr $ra
|
|
|
|
addiu $sp, $sp, 8
|
|
|
|
$BB0_2: # %entry
|
|
|
|
sll $1, $2, 2
|
|
|
|
lui $2, %hi($JTI0_0)
|
|
|
|
addu $1, $1, $2
|
|
|
|
lw $1, %lo($JTI0_0)($1)
|
|
|
|
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:
|
|
|
|
.4byte ($BB0_3)
|
|
|
|
.4byte ($BB0_4)
|
|
|
|
.4byte ($BB0_5)
|
|
|
|
.4byte ($BB0_6)
|
|
|
|
|
|
|
|
|
|
|
|
.text
|