2013-02-21 07:11:17 +08:00
|
|
|
# RUN: llvm-mc %s -triple=mipsel-unknown-linux -show-encoding -mcpu=mips32r2 | \
|
|
|
|
# RUN: FileCheck %s
|
|
|
|
# Check that the assembler can handle the documented syntax
|
|
|
|
# for ".set at" and set the correct value.
|
|
|
|
.text
|
|
|
|
foo:
|
2014-03-25 19:16:03 +08:00
|
|
|
# CHECK: lui $1, 1
|
|
|
|
# CHECK: addu $1, $1, $2
|
|
|
|
# CHECK: lw $2, 0($1)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$1
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $2, 65536($2)
|
|
|
|
# CHECK: lui $2, 1
|
|
|
|
# CHECK: addu $2, $2, $1
|
|
|
|
# CHECK: lw $1, 0($2)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$2
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $3, 1
|
|
|
|
# CHECK: addu $3, $3, $1
|
|
|
|
# CHECK: lw $1, 0($3)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$3
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $4, 1
|
|
|
|
# CHECK: addu $4, $4, $1
|
|
|
|
# CHECK: lw $1, 0($4)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$a0
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $5, 1
|
|
|
|
# CHECK: addu $5, $5, $1
|
|
|
|
# CHECK: lw $1, 0($5)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$a1
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $6, 1
|
|
|
|
# CHECK: addu $6, $6, $1
|
|
|
|
# CHECK: lw $1, 0($6)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$a2
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $7, 1
|
|
|
|
# CHECK: addu $7, $7, $1
|
|
|
|
# CHECK: lw $1, 0($7)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$a3
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $8, 1
|
|
|
|
# CHECK: addu $8, $8, $1
|
|
|
|
# CHECK: lw $1, 0($8)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$8
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $9, 1
|
|
|
|
# CHECK: addu $9, $9, $1
|
|
|
|
# CHECK: lw $1, 0($9)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$9
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $10, 1
|
|
|
|
# CHECK: addu $10, $10, $1
|
|
|
|
# CHECK: lw $1, 0($10)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$10
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $11, 1
|
|
|
|
# CHECK: addu $11, $11, $1
|
|
|
|
# CHECK: lw $1, 0($11)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$11
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $12, 1
|
|
|
|
# CHECK: addu $12, $12, $1
|
|
|
|
# CHECK: lw $1, 0($12)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$12
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $13, 1
|
|
|
|
# CHECK: addu $13, $13, $1
|
|
|
|
# CHECK: lw $1, 0($13)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$13
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $14, 1
|
|
|
|
# CHECK: addu $14, $14, $1
|
|
|
|
# CHECK: lw $1, 0($14)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$14
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $15, 1
|
|
|
|
# CHECK: addu $15, $15, $1
|
|
|
|
# CHECK: lw $1, 0($15)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$15
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $16, 1
|
|
|
|
# CHECK: addu $16, $16, $1
|
|
|
|
# CHECK: lw $1, 0($16)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$s0
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $17, 1
|
|
|
|
# CHECK: addu $17, $17, $1
|
|
|
|
# CHECK: lw $1, 0($17)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$s1
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $18, 1
|
|
|
|
# CHECK: addu $18, $18, $1
|
|
|
|
# CHECK: lw $1, 0($18)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$s2
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $19, 1
|
|
|
|
# CHECK: addu $19, $19, $1
|
|
|
|
# CHECK: lw $1, 0($19)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$s3
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $20, 1
|
|
|
|
# CHECK: addu $20, $20, $1
|
|
|
|
# CHECK: lw $1, 0($20)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$s4
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $21, 1
|
|
|
|
# CHECK: addu $21, $21, $1
|
|
|
|
# CHECK: lw $1, 0($21)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$s5
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $22, 1
|
|
|
|
# CHECK: addu $22, $22, $1
|
|
|
|
# CHECK: lw $1, 0($22)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$s6
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $23, 1
|
|
|
|
# CHECK: addu $23, $23, $1
|
|
|
|
# CHECK: lw $1, 0($23)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$s7
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $24, 1
|
|
|
|
# CHECK: addu $24, $24, $1
|
|
|
|
# CHECK: lw $1, 0($24)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$24
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $25, 1
|
|
|
|
# CHECK: addu $25, $25, $1
|
|
|
|
# CHECK: lw $1, 0($25)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$25
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $26, 1
|
|
|
|
# CHECK: addu $26, $26, $1
|
|
|
|
# CHECK: lw $1, 0($26)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$26
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $27, 1
|
|
|
|
# CHECK: addu $27, $27, $1
|
|
|
|
# CHECK: lw $1, 0($27)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$27
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $gp, 1
|
|
|
|
# CHECK: addu $gp, $gp, $1
|
|
|
|
# CHECK: lw $1, 0($gp)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$gp
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $fp, 1
|
|
|
|
# CHECK: addu $fp, $fp, $1
|
|
|
|
# CHECK: lw $1, 0($fp)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$fp
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $sp, 1
|
|
|
|
# CHECK: addu $sp, $sp, $1
|
|
|
|
# CHECK: lw $1, 0($sp)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$sp
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|
|
|
|
# CHECK: lui $ra, 1
|
|
|
|
# CHECK: addu $ra, $ra, $1
|
|
|
|
# CHECK: lw $1, 0($ra)
|
2013-02-21 07:11:17 +08:00
|
|
|
.set at=$ra
|
2014-03-25 19:16:03 +08:00
|
|
|
lw $1, 65536($1)
|