llvm-6502/test/MC/Disassembler/Mips/mips32r2_le.txt
Akira Hatanaka b66510f309 In MipsDisassembler.cpp, instead of defining register class tables, use the ones
that are generated by TableGen and are already available in
MipsGenRegisterInfo.inc. Suggested by Jakob Stoklund Olesen.

Also, fix bug in function DecodeAFGR64RegisterClass.

Patch by Vladimir Medic. 


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@158846 91177308-0d34-0410-b5e6-96231b3b80d8
2012-06-20 20:39:23 +00:00

443 lines
6.5 KiB
Plaintext

# RUN: llvm-mc --disassemble %s -triple=mipsel-unknown-linux -mcpu=mips32r2
# CHECK: abs.d $f12,$f14
0x05 0x73 0x20 0x46
# CHECK: abs.s $f6,$f7
0x85 0x39 0x00 0x46
# CHECK: add t1,a2,a3
0x20 0x48 0xc7 0x00
# CHECK: add.d $8,$f12,$f14
0x00 0x62 0x2e 0x46
# CHECK: add.s $f9,$f6,$f7
0x40 0x32 0x07 0x46
# CHECK: addi t1,a2,17767
0x67 0x45 0xc9 0x20
# CHECK: addiu t1,a2,-15001
0x67 0xc5 0xc9 0x24
# CHECK: addu t1,a2,a3
0x21 0x48 0xc7 0x00
# CHECK: and t1,a2,a3
0x24 0x48 0xc7 0x00
# CHECK: andi t1,a2,0x4567
0x67 0x45 0xc9 0x30
# CHECK: b 00000534
0x4c 0x01 0x00 0x10
# CHECK: bal 00000534
0x4c 0x01 0x11 0x04
# CHECK: bc1f 00000534
0x4c 0x01 0x00 0x45
# CHECK: bc1t 00000534
0x4c 0x01 0x01 0x45
# CHECK: beq t1,a2,00000534
0x4c 0x01 0x26 0x11
# CHECK: bgez a2,00000534
0x4c 0x01 0xc1 0x04
# CHECK: bgezal a2,00000534
0x4c 0x01 0xd1 0x04
# CHECK: bgtz a2,00000534
0x4c 0x01 0xc0 0x1c
# CHECK: blez a2,00000534
0x4c 0x01 0xc0 0x18
# CHECK: bne t1,a2,00000534
0x4c 0x01 0x26 0x15
# CHECK: c.eq.d $f12,$f14
0x32 0x60 0x2e 0x46
# CHECK: c.eq.s $f6,$f7
0x32 0x30 0x07 0x46
# CHECK: c.f.d $f12,$f14
0x30 0x60 0x2e 0x46
# CHECK: c.f.s $f6,$f7
0x30 0x30 0x07 0x46
# CHECK: c.le.d $f12,$f14
0x3e 0x60 0x2e 0x46
# CHECK: c.le.s $f6,$f7
0x3e 0x30 0x07 0x46
# CHECK: c.lt.d $f12,$f14
0x3c 0x60 0x2e 0x46
# CHECK: c.lt.s $f6,$f7
0x3c 0x30 0x07 0x46
# CHECK: c.nge.d $f12,$f14
0x3d 0x60 0x2e 0x46
# CHECK: c.nge.s $f6,$f7
0x3d 0x30 0x07 0x46
# CHECK: c.ngl.d $f12,$f14
0x3b 0x60 0x2e 0x46
# CHECK: c.ngl.s $f6,$f7
0x3b 0x30 0x07 0x46
# CHECK: c.ngle.d $f12,$f14
0x39 0x60 0x2e 0x46
# CHECK: c.ngle.s $f6,$f7
0x39 0x30 0x07 0x46
# CHECK: c.ngt.d $f12,$f14
0x3f 0x60 0x2e 0x46
# CHECK: c.ngt.s $f6,$f7
0x3f 0x30 0x07 0x46
# CHECK: c.ole.d $f12,$f14
0x36 0x60 0x2e 0x46
# CHECK: c.ole.s $f6,$f7
0x36 0x30 0x07 0x46
# CHECK: c.olt.d $f12,$f14
0x34 0x60 0x2e 0x46
# CHECK: c.olt.s $f6,$f7
0x34 0x30 0x07 0x46
# CHECK: c.seq.d $f12,$f14
0x3a 0x60 0x2e 0x46
# CHECK: c.seq.s $f6,$f7
0x3a 0x30 0x07 0x46
# CHECK: c.sf.d $f12,$f14
0x38 0x60 0x2e 0x46
# CHECK: c.sf.s $f6,$f7
0x38 0x30 0x07 0x46
# CHECK: c.ueq.d $f12,$f14
0x33 0x60 0x2e 0x46
# CHECK: c.ueq.s $f28,$f18
0x33 0xe0 0x12 0x46
# CHECK: c.ule.d $f12,$f14
0x37 0x60 0x2e 0x46
# CHECK: c.ule.s $f6,$f7
0x37 0x30 0x07 0x46
# CHECK: c.ult.d $f12,$f14
0x35 0x60 0x2e 0x46
# CHECK: c.ult.s $f6,$f7
0x35 0x30 0x07 0x46
# CHECK: c.un.d $f12,$f14
0x31 0x60 0x2e 0x46
# CHECK: c.un.s $f6,$f7
0x31 0x30 0x07 0x46
# CHECK: ceil.w.d $f12,$f14
0x0e 0x73 0x20 0x46
# CHECK: ceil.w.s $f6,$f7
0x0e 0x73 0x20 0x46
# CHECK: cfc1 a2,$7
0x00 0x38 0x46 0x44
# CHECK: clo a2,a3
0x21 0x30 0xe6 0x70
# CHECK: clz a2,a3
0x20 0x30 0xe6 0x70
# CHECK: ctc1 a2,$7
0x00 0x38 0xc6 0x44
# CHECK: cvt.d.s $f6,$f7
0xa1 0x39 0x00 0x46
# CHECK: cvt.d.w $f12,$f14
0x21 0x73 0x80 0x46
# CHECK: cvt.l.d $f12,$f14
0x05 0x73 0x20 0x46
# CHECK: cvt.l.s $f6,$f7
0xa5 0x39 0x00 0x46
# CHECK: cvt.s.d $f12,$f14
0x20 0x73 0x20 0x46
# CHECK: cvt.s.w $f6,$f7
0xa0 0x39 0x80 0x46
# CHECK: cvt.w.d $f12,$f14
0x24 0x73 0x20 0x46
# CHECK: cvt.w.s $f6,$f7
0xa4 0x39 0x00 0x46
# CHECK: floor.w.d $f12,$f14
0x0f 0x73 0x20 0x46
# CHECK: floor.w.s $f6,$f7
0x8f 0x39 0x00 0x46
# CHECK: ins s3,t1,0x6,0x7
0x84 0x61 0x33 0x7d
# CHECK: j 00000530
0x4c 0x01 0x00 0x08
# CHECK: jal 00000530
0x4c 0x01 0x00 0x0c
# CHECK: jalr a3
0x09 0xf8 0xe0 0x00
# CHECK: jr a3
0x08 0x00 0xe0 0x00
# CHECK: lb a0,9158(a1)
0xc6 0x23 0xa4 0x80
# CHECK: lbu a0,6(a1)
0x06 0x00 0xa4 0x90
# CHECK: ldc1 $f9,9158(a3)
0xc6 0x23 0xe9 0xd4
# CHECK: lh a0,12(a1)
0x0c 0x00 0xa4 0x84
# CHECK: lh a0,12(a1)
0x0c 0x00 0xa4 0x84
# CHECK: li v1,17767
0x67 0x45 0x03 0x24
# CHECK: ll t1,9158(a3)
0xc6 0x23 0xe9 0xc0
# CHECK: lui a2,0x4567
0x67 0x45 0x06 0x3c
# CHECK: lw a0,24(a1)
0x18 0x00 0xa4 0x8c
# CHECK lw at,-18316(v0)
0x74 0xb8 0x41 0x8c
# CHECK: lwc1 $f9,9158(a3)
0xc6 0x23 0xe9 0xc4
# CHECK: madd a2,a3
0x00 0x00 0xc7 0x70
# CHECK: maddu a2,a3
0x01 0x00 0xc7 0x70
# CHECK: mfc1 a2,$f7
0x00 0x38 0x06 0x44
# CHECK: mfhi a1
0x10 0x28 0x00 0x00
# CHECK: mflo a1
0x12 0x28 0x00 0x00
# CHECK: mov.d $f6,$f8
0x86 0x41 0x20 0x46
# CHECK: mov.s $f6,$f7
0x86 0x39 0x00 0x46
# CHECK: move a2,a1
0x21 0x30 0xa0 0x00
# CHECK: msub a2,a3
0x04 0x00 0xc7 0x70
# CHECK: msubu a2,a3
0x05 0x00 0xc7 0x70
# CHECK: mtc1 a2,$f7
0x00 0x38 0x86 0x44
# CHECK: mthi a3
0x11 0x00 0xe0 0x00
# CHECK: mtlo a3
0x13 0x00 0xe0 0x00
# CHECK: mul.d $f8,$f12,$f14
0x02 0x62 0x2e 0x46
# CHECK: mul.s $f9,$f6,$f7
0x02 0x62 0x07 0x46
# CHECK: mul t1,a2,a3
0x02 0x48 0xc7 0x70
# CHECK: mult v1,a1
0x18 0x00 0x65 0x00
# CHECK: multu v1,a1
0x19 0x00 0x65 0x00
# CHECK: neg.d $f12,$f14
0x07 0x73 0x20 0x46
# CHECK: neg.s $f6,$f7
0x87 0x39 0x00 0x46
# CHECK: neg v1,a1
0x22 0x18 0x05 0x00
# CHECK: nop
0x00 0x00 0x00 0x00
# CHECK: nor t1,a2,a3
0x27 0x48 0xc7 0x00
# CHECK: not v1,a1
0x27 0x18 0xa0 0x00
# CHECK: or v1,v1,a1
0x25 0x18 0x65 0x00
# CHECK: ori t1,a2,0x4567
0x67 0x45 0xc9 0x34
# CHECK: rdhwr a2,$29
0x3b 0xe8 0x06 0x7c
# CHECK: ror t1,a2,0x7
0xc2 0x49 0x26 0x00
# CHECK: rorv t1,a2,a3
0x46 0x48 0xe6 0x00
# CHECK: round.w.d $f12,$f14
0x0c 0x73 0x20 0x46
# CHECK: round.w.s $f6,$f7
0x8c 0x39 0x00 0x46
# CHECK: sb a0,9158(a1)
0xc6 0x23 0xa4 0xa0
# CHECK: sb a0,6(a1)
0x06 0x00 0xa4 0xa0
# CHECK: sc t1,9158(a3)
0xc6 0x23 0xe9 0xe0
# CHECK: sdc1 $f9,9158(a3)
0xc6 0x23 0xe9 0xf4
# CHECK: seb a2,a3
0x20 0x34 0x07 0x7c
# CHECK: seh a2,a3
0x20 0x36 0x07 0x7c
# CHECK: sh a0,9158(a1)
0xc6 0x23 0xa4 0xa4
# CHECK: sll a0,v1,0x7
0xc0 0x21 0x03 0x00
# CHECK: sllv v0,v1,a1
0x04 0x10 0xa3 0x00
# CHECK: slt v1,v1,a1
0x2a 0x18 0x65 0x00
# CHECK: slti v1,v1,103
0x67 0x00 0x63 0x28
# CHECK: sltiu v1,v1,103
0x67 0x00 0x63 0x2c
# CHECK: sltu v1,v1,a1
0x2b 0x18 0x65 0x00
# CHECK: sqrt.d $f12,$f14
0x04 0x73 0x20 0x46
# CHECK: sqrt.s $f6,$f7
0x84 0x39 0x00 0x46
# CHECK: sra a0,v1,0x7
0xc3 0x21 0x03 0x00
# CHECK: sra a0,v1,0x7
0xc3 0x21 0x03 0x00
# CHECK: srav v0,v1,a1
0x07 0x10 0xa3 0x00
# CHECK: srl a0,v1,0x7
0xc2 0x21 0x03 0x00
# CHECK: srlv v0,v1,a1
0x06 0x10 0xa3 0x00
# CHECK: sub.d $f8,$f12,$f14
0x01 0x62 0x2e 0x46
# CHECK: sub.s $f9,$f6,$f7
0x41 0x32 0x07 0x46
# CHECK: sub t1,a2,a3
0x22 0x48 0xc7 0x00
# CHECK: subu a0,v1,a1
0x23 0x20 0x65 0x00
# CHECK: sw a0,24(a1)
0x18 0x00 0xa4 0xac
# CHECK: swc1 $f9,9158(a3)
0xc6 0x23 0xe9 0xe4
# CHECK: sync 0x7
0xcf 0x01 0x00 0x00
# CHECK: trunc.w.d $f12,$f14
0x0d 0x73 0x20 0x46
# CHECK: trunc.w.s $f6,$f7
0x8d 0x39 0x00 0x46
# CHECK: wsbh a2,a3
0xa0 0x30 0x07 0x7c
# CHECK: xor v1,v1,a1
0x26 0x18 0x65 0x00
# CHECK: xori t1,a2,0x4567
0x67 0x45 0xc9 0x38