From: Vladimir Medic Date: Thu, 15 Jan 2015 08:50:20 +0000 (+0000) Subject: Add disassembler tests for mips64 platform. There are no functional changes. X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=e993dac523138a53f342ddc3a8cc314de379f250;p=platform%2Fupstream%2Fllvm.git Add disassembler tests for mips64 platform. There are no functional changes. llvm-svn: 226151 --- diff --git a/llvm/test/MC/Disassembler/Mips/mips64/valid-mips64-el.txt b/llvm/test/MC/Disassembler/Mips/mips64/valid-mips64-el.txt new file mode 100644 index 0000000..0cee513 --- /dev/null +++ b/llvm/test/MC/Disassembler/Mips/mips64/valid-mips64-el.txt @@ -0,0 +1,428 @@ +# RUN: llvm-mc --disassemble %s -triple=mips64el-unknown-linux | FileCheck %s + +0x05 0x73 0x20 0x46 #CHECK: abs.d $f12, $f14 + +0x85 0x39 0x00 0x46 #CHECK: abs.s $f6, $f7 + +0x20 0x48 0xc7 0x00 #CHECK: add $9, $6, $7 + +0x00 0x62 0x2e 0x46 #CHECK: add.d $f8, $f12, $f14 + +0x40 0x32 0x07 0x46 #CHECK: add.s $f9, $f6, $f7 + +0x67 0x45 0xc9 0x20 #CHECK: addi $9, $6, 17767 + +0x67 0xc5 0xc9 0x24 #CHECK: addiu $9, $6, -15001 + +0x21 0x48 0xc7 0x00 #CHECK: addu $9, $6, $7 + +0x24 0x48 0xc7 0x00 #CHECK: and $9, $6, $7 + +0x67 0x45 0xc9 0x30 #CHECK: andi $9, $6, 17767 + +0x4c 0x01 0x00 0x10 #CHECK: b 1332 + +0x4c 0x01 0x00 0x45 #CHECK: bc1f 1332 + +0x4c 0x01 0x1c 0x45 #CHECK: bc1f $fcc7, 1332 + +0x4c 0x01 0x01 0x45 #CHECK: bc1t 1332 + +0x4c 0x01 0x1d 0x45 #CHECK: bc1t $fcc7, 1332 + +0x4c 0x01 0x26 0x11 #CHECK: beq $9, $6, 1332 + +0x4c 0x01 0xc1 0x04 #CHECK: bgez $6, 1332 + +0x4c 0x01 0xd1 0x04 #CHECK: bgezal $6, 1332 + +0x4c 0x01 0xc0 0x1c #CHECK: bgtz $6, 1332 + +0x4c 0x01 0xc0 0x18 #CHECK: blez $6, 1332 + +0x4c 0x01 0x26 0x15 #CHECK: bne $9, $6, 1332 + +0x32 0x60 0x2e 0x46 #CHECK: c.eq.d $f12, $f14 + +0x32 0x30 0x07 0x46 #CHECK: c.eq.s $f6, $f7 + +0x30 0x60 0x2e 0x46 #CHECK: c.f.d $f12, $f14 + +0x30 0x30 0x07 0x46 #CHECK: c.f.s $f6, $f7 + +0x3e 0x60 0x2e 0x46 #CHECK: c.le.d $f12, $f14 + +0x3e 0x30 0x07 0x46 #CHECK: c.le.s $f6, $f7 + +0x3c 0x60 0x2e 0x46 #CHECK: c.lt.d $f12, $f14 + +0x3c 0x30 0x07 0x46 #CHECK: c.lt.s $f6, $f7 + +0x3d 0x60 0x2e 0x46 #CHECK: c.nge.d $f12, $f14 + +0x3d 0x30 0x07 0x46 #CHECK: c.nge.s $f6, $f7 + +0x3b 0x60 0x2e 0x46 #CHECK: c.ngl.d $f12, $f14 + +0x3b 0x30 0x07 0x46 #CHECK: c.ngl.s $f6, $f7 + +0x39 0x60 0x2e 0x46 #CHECK: c.ngle.d $f12, $f14 + +0x39 0x30 0x07 0x46 #CHECK: c.ngle.s $f6, $f7 + +0x3f 0x60 0x2e 0x46 #CHECK: c.ngt.d $f12, $f14 + +0x3f 0x30 0x07 0x46 #CHECK: c.ngt.s $f6, $f7 + +0x36 0x60 0x2e 0x46 #CHECK: c.ole.d $f12, $f14 + +0x36 0x30 0x07 0x46 #CHECK: c.ole.s $f6, $f7 + +0x34 0x60 0x2e 0x46 #CHECK: c.olt.d $f12, $f14 + +0x34 0x30 0x07 0x46 #CHECK: c.olt.s $f6, $f7 + +0x3a 0x60 0x2e 0x46 #CHECK: c.seq.d $f12, $f14 + +0x3a 0x30 0x07 0x46 #CHECK: c.seq.s $f6, $f7 + +0x38 0x60 0x2e 0x46 #CHECK: c.sf.d $f12, $f14 + +0x38 0x30 0x07 0x46 #CHECK: c.sf.s $f6, $f7 + +0x33 0x60 0x2e 0x46 #CHECK: c.ueq.d $f12, $f14 + +0x33 0xe0 0x12 0x46 #CHECK: c.ueq.s $f28, $f18 + +0x37 0x60 0x2e 0x46 #CHECK: c.ule.d $f12, $f14 + +0x37 0x30 0x07 0x46 #CHECK: c.ule.s $f6, $f7 + +0x35 0x60 0x2e 0x46 #CHECK: c.ult.d $f12, $f14 + +0x35 0x30 0x07 0x46 #CHECK: c.ult.s $f6, $f7 + +0x31 0x60 0x2e 0x46 #CHECK: c.un.d $f12, $f14 + +0x31 0x30 0x07 0x46 #CHECK: c.un.s $f6, $f7 + +0x0e 0x73 0x20 0x46 #CHECK: ceil.w.d $f12, $f14 + +0x8e 0x39 0x00 0x46 #CHECK: ceil.w.s $f6, $f7 + +0x4a 0x18 0x20 0x46 #CHECK: ceil.l.d $f1, $f3 + +0x8a 0x6c 0x00 0x46 #CHECK: ceil.l.s $f18, $f13 + +0x00 0x38 0x46 0x44 #CHECK: cfc1 $6, $7 + +0x21 0x30 0xe6 0x70 #CHECK: clo $6, $7 + +0x20 0x30 0xe6 0x70 #CHECK: clz $6, $7 + +0x00 0x38 0xc6 0x44 #CHECK: ctc1 $6, $7 + +0xa1 0x39 0x00 0x46 #CHECK: cvt.d.s $f6, $f7 + +0x21 0x81 0xa0 0x46 #CHECK: cvt.d.l $f4, $f16 + +0x21 0x73 0x80 0x46 #CHECK: cvt.d.w $f12, $f14 + +0x20 0x73 0x20 0x46 #CHECK: cvt.s.d $f12, $f14 + +0xe0 0xf3 0xa0 0x46 #CHECK: cvt.s.l $f15, $f30 + +0xa0 0x39 0x80 0x46 #CHECK: cvt.s.w $f6, $f7 + +0x24 0x73 0x20 0x46 #CHECK: cvt.w.d $f12, $f14 + +0xa4 0x39 0x00 0x46 #CHECK: cvt.w.s $f6, $f7 + +0x2c 0x98 0x3f 0x00 #CHECK: dadd $19, $1, $ra + +0xc7 0x93 0x9d 0x62 #CHECK: daddi $sp, $20, -27705 + +0xc7 0x93 0xbd 0x63 #CHECK: daddi $sp, $sp, -27705 + +0xc7 0x93 0x9d 0x62 #CHECK: daddi $sp, $20, -27705 + +0xc7 0x93 0x9d 0x62 #CHECK: daddi $sp, $20, -27705 + +0xc7 0x93 0xbd 0x63 #CHECK: daddi $sp, $sp, -27705 + +0x16 0xee 0xda 0x66 #CHECK: daddiu $26, $22, -4586 + +0x2d 0x98 0x3f 0x00 #CHECK: daddu $19, $1, $ra + +0x9f 0x46 0x58 0x64 #CHECK: daddiu $24, $2, 18079 + +0x3f 0x69 0x73 0x66 #CHECK: daddiu $19, $19, 26943 + +0x25 0x90 0xd2 0x70 #CHECK: dclo $18, $6 + +0x24 0x80 0x30 0x73 #CHECK: dclz $16, $25 + +0x1e 0x00 0x53 0x03 #CHECK: ddiv $zero, $26, $19 + +0x1f 0x00 0x11 0x02 #CHECK: ddivu $zero, $16, $17 + +0x00 0x68 0x2c 0x44 #CHECK: dmfc1 $12, $f13 + +0x00 0x70 0xb0 0x44 #CHECK: dmtc1 $16, $f14 + +0x1c 0x00 0xe9 0x02 #CHECK: dmult $23, $9 + +0x1d 0x00 0xa6 0x00 #CHECK: dmultu $5, $6 + +0xb8 0x04 0x00 0x00 #CHECK: dsll $zero, $zero, 18 + +0xb8 0x04 0x14 0x00 #CHECK: dsll $zero, $20, 18 + +0x14 0x00 0x94 0x01 #CHECK: dsllv $zero, $20, $12 + +0xbc 0x04 0x00 0x00 #CHECK: dsll32 $zero, $zero, 18 + +0xbc 0x04 0x00 0x00 #CHECK: dsll32 $zero, $zero, 18 + +0x14 0x00 0x94 0x01 #CHECK: dsllv $zero, $20, $12 + +0xbb 0xe2 0x1c 0x00 #CHECK: dsra $gp, $gp, 10 + +0xbb 0xe2 0x12 0x00 #CHECK: dsra $gp, $18, 10 + +0x17 0xe0 0x72 0x02 #CHECK: dsrav $gp, $18, $19 + +0xbf 0xe2 0x1c 0x00 #CHECK: dsra32 $gp, $gp, 10 + +0xbf 0xe2 0x12 0x00 #CHECK: dsra32 $gp, $18, 10 + +0x17 0xe0 0x72 0x02 #CHECK: dsrav $gp, $18, $19 + +0xfa 0x9d 0x13 0x00 #CHECK: dsrl $19, $19, 23 + +0xfa 0x9d 0x06 0x00 #CHECK: dsrl $19, $6, 23 + +0x16 0x98 0x86 0x02 #CHECK: dsrlv $19, $6, $20 + +0xfe 0x9d 0x13 0x00 #CHECK: dsrl32 $19, $19, 23 + +0xfe 0x9d 0x06 0x00 #CHECK: dsrl32 $19, $6, 23 + +0x16 0x98 0x86 0x02 #CHECK: dsrlv $19, $6, $20 + +0x2e 0x38 0xc8 0x02 #CHECK: dsub $7, $22, $8 + +0x39 0x6c 0x9d 0x62 #CHECK: daddi $sp, $20, 27705 + +0x39 0x6c 0xbd 0x63 #CHECK: daddi $sp, $sp, 27705 + +0x2f 0x28 0xba 0x00 #CHECK: dsubu $5, $5, $26 + +0x5f 0xec 0x6f 0x65 #CHECK: daddiu $15, $11, -5025 + +0xea 0x11 0xce 0x65 #CHECK: daddiu $14, $14, 4586 + +0x8b 0x3e 0x20 0x46 #CHECK: floor.l.d $f26, $f7 + +0x0b 0x2b 0x00 0x46 #CHECK: floor.l.s $f12, $f5 + +0x0f 0x73 0x20 0x46 #CHECK: floor.w.d $f12, $f14 + +0x8f 0x39 0x00 0x46 #CHECK: floor.w.s $f6, $f7 + +0x4c 0x01 0x00 0x08 #CHECK: j 1328 + +0x4c 0x01 0x00 0x0c #CHECK: jal 1328 + +0x4c 0x01 0x00 0x74 #CHECK: jalx 1328 + +0x09 0xf8 0xe0 0x00 #CHECK: jalr $7 + +0x09 0xfc 0x80 0x00 #CHECK: jalr.hb $4 + +0x09 0x24 0xa0 0x00 #CHECK: jalr.hb $4, $5 + +0x08 0x00 0xe0 0x00 #CHECK: jr $7 + +0xc6 0x23 0xa4 0x80 #CHECK: lb $4, 9158($5) + +0x06 0x00 0xa4 0x90 #CHECK: lbu $4, 6($5) + +0xc6 0x23 0xe9 0xd4 #CHECK: ldc1 $f9, 9158($7) + +0x1b 0x90 0x3d 0xde #CHECK: ld $sp, -28645($17) + +0xb9 0xef 0x18 0x6b #CHECK: ldl $24, -4167($24) + +0x6a 0x89 0x8e 0x6e #CHECK: ldr $14, -30358($20) + +0x01 0x02 0xf7 0x4d #CHECK: ldxc1 $f8, $23($15) + +0x0c 0x00 0xa4 0x84 #CHECK: lh $4, 12($5) + +0x0c 0x00 0xa4 0x84 #CHECK: lh $4, 12($5) + +0xc6 0x23 0xe9 0xc0 #CHECK: ll $9, 9158($7) + +0x70 0xc6 0xe0 0xd3 #CHECK: lld $zero, -14736($ra) + +0x67 0x45 0x06 0x3c #CHECK: lui $6, 17767 + +0xc5 0x04 0xb6 0x4e #CHECK: luxc1 $f19, $22($21) + +0xea 0xa1 0x73 0x9c #CHECK: lwu $19, -24086($3) + +0x00 0x03 0xd1 0x4f #CHECK: lwxc1 $f12, $17($fp) + +0x18 0x00 0xa4 0x8c #CHECK: lw $4, 24($5) + +0xc6 0x23 0xe9 0xc4 #CHECK: lwc1 $f9, 9158($7) + +0x03 0x00 0x82 0x88 #CHECK: lwl $2, 3($4) + +0x10 0x00 0xa3 0x98 #CHECK: lwr $3, 16($5) + +0x00 0x00 0xc7 0x70 #CHECK: madd $6, $7 + +0x01 0x00 0xc7 0x70 #CHECK: maddu $6, $7 + +0x00 0x38 0x06 0x44 #CHECK: mfc1 $6, $f7 + +0x10 0x28 0x00 0x00 #CHECK: mfhi $5 + +0x12 0x28 0x00 0x00 #CHECK: mflo $5 + +0x86 0x41 0x20 0x46 #CHECK: mov.d $f6, $f8 + +0x86 0x39 0x00 0x46 #CHECK: mov.s $f6, $f7 + +0x04 0x00 0xc7 0x70 #CHECK: msub $6, $7 + +0x05 0x00 0xc7 0x70 #CHECK: msubu $6, $7 + +0x00 0x38 0x86 0x44 #CHECK: mtc1 $6, $f7 + +0x11 0x00 0xe0 0x00 #CHECK: mthi $7 + +0x13 0x00 0xe0 0x00 #CHECK: mtlo $7 + +0x02 0x62 0x2e 0x46 #CHECK: mul.d $f8, $f12, $f14 + +0x42 0x32 0x07 0x46 #CHECK: mul.s $f9, $f6, $f7 + +0x02 0x48 0xc7 0x70 #CHECK: mul $9, $6, $7 + +0x18 0x00 0x65 0x00 #CHECK: mult $3, $5 + +0x19 0x00 0x65 0x00 #CHECK: multu $3, $5 + +0x07 0x73 0x20 0x46 #CHECK: neg.d $f12, $f14 + +0x87 0x39 0x00 0x46 #CHECK: neg.s $f6, $f7 + +0x00 0x00 0x00 0x00 #CHECK: nop + +0x27 0x48 0xc7 0x00 #CHECK: nor $9, $6, $7 + +0x25 0x18 0x65 0x00 #CHECK: or $3, $3, $5 + +0x67 0x45 0xc9 0x34 #CHECK: ori $9, $6, 17767 + +0x08 0x0b 0x20 0x46 #CHECK: round.l.d $f12, $f1 + +0x48 0x2e 0x00 0x46 #CHECK: round.l.s $f25, $f5 + +0x0c 0x73 0x20 0x46 #CHECK: round.w.d $f12, $f14 + +0x8c 0x39 0x00 0x46 #CHECK: round.w.s $f6, $f7 + +0xc6 0x23 0xa4 0xa0 #CHECK: sb $4, 9158($5) + +0x06 0x00 0xa4 0xa0 #CHECK: sb $4, 6($5) + +0xc6 0x23 0xe9 0xe0 #CHECK: sc $9, 9158($7) + +0xcd 0xdf 0xaf 0xf3 #CHECK: scd $15, -8243($sp) + +0xcb 0x16 0x4c 0xfd #CHECK: sd $12, 5835($10) + +0xc6 0x23 0xe9 0xf4 #CHECK: sdc1 $f9, 9158($7) + +0x1f 0xae 0xc7 0xb3 #CHECK: sdl $7, -20961($fp) + +0x39 0xb0 0x8b 0xb5 #CHECK: sdr $11, -20423($12) + +0x09 0x58 0xca 0x4d #CHECK: sdxc1 $f11, $10($14) + +0xc6 0x23 0xa4 0xa4 #CHECK: sh $4, 9158($5) + +0xc0 0x21 0x03 0x00 #CHECK: sll $4, $3, 7 + +0x04 0x10 0xa3 0x00 #CHECK: sllv $2, $3, $5 + +0x2a 0x18 0x65 0x00 #CHECK: slt $3, $3, $5 + +0x67 0x00 0x63 0x28 #CHECK: slti $3, $3, 103 + +0x67 0x00 0x63 0x2c #CHECK: sltiu $3, $3, 103 + +0x2b 0x18 0x65 0x00 #CHECK: sltu $3, $3, $5 + +0x04 0x73 0x20 0x46 #CHECK: sqrt.d $f12, $f14 + +0x84 0x39 0x00 0x46 #CHECK: sqrt.s $f6, $f7 + +0xc3 0x21 0x03 0x00 #CHECK: sra $4, $3, 7 + +0x07 0x10 0xa3 0x00 #CHECK: srav $2, $3, $5 + +0xc2 0x21 0x03 0x00 #CHECK: srl $4, $3, 7 + +0x06 0x10 0xa3 0x00 #CHECK: srlv $2, $3, $5 + +0x01 0x62 0x2e 0x46 #CHECK: sub.d $f8, $f12, $f14 + +0x41 0x32 0x07 0x46 #CHECK: sub.s $f9, $f6, $f7 + +0x22 0x48 0xc7 0x00 #CHECK: sub $9, $6, $7 + +0x23 0x20 0x65 0x00 #CHECK: subu $4, $3, $5 + +0x18 0x00 0xa4 0xac #CHECK: sw $4, 24($5) + +0xc6 0x23 0xe9 0xe4 #CHECK: swc1 $f9, 9158($7) + +0x0d 0x60 0xbb 0x4d #CHECK: suxc1 $f12, $27($13) + +0x08 0x98 0x4c 0x4f #CHECK: swxc1 $f19, $12($26) + +0x10 0x00 0xa4 0xa8 #CHECK: swl $4, 16($5) + +0x10 0x00 0xe6 0xb8 #CHECK: swr $6, 16($7) + +0xcf 0x01 0x00 0x00 #CHECK: sync 7 + +0xc9 0xbd 0x20 0x46 #CHECK: trunc.l.d $f23, $f23 + +0x09 0xff 0x00 0x46 #CHECK: trunc.l.s $f28, $f31 + +0x0d 0x73 0x20 0x46 #CHECK: trunc.w.d $f12, $f14 + +0x8d 0x39 0x00 0x46 #CHECK: trunc.w.s $f6, $f7 + +0x26 0x18 0x65 0x00 #CHECK: xor $3, $3, $5 + +0x67 0x45 0xc9 0x38 #CHECK: xori $9, $6, 17767 + +0x3b 0xe8 0x05 0x7c #CHECK: .set push + #CHECK: .set mips32r2 + #CHECK: rdhwr $5, $29 + #CHECK: .set pop + +0x02 0x00 0x61 0xbc #CHECK: cache 1, 2($3) + +0x04 0x00 0x43 0xcc #CHECK: pref 3, 4($2) + +0xc6 0x23 0xe9 0xe8 #CHECK: swc2 $9, 9158($7) + +0xca 0x23 0xc8 0xc8 #CHECK: lwc2 $8, 9162($6) diff --git a/llvm/test/MC/Disassembler/Mips/mips64/valid-mips64-xfail.txt b/llvm/test/MC/Disassembler/Mips/mips64/valid-mips64-xfail.txt new file mode 100644 index 0000000..5dff376 --- /dev/null +++ b/llvm/test/MC/Disassembler/Mips/mips64/valid-mips64-xfail.txt @@ -0,0 +1,80 @@ +# RUN: llvm-mc %s -triple=mips-unknown-linux -disassemble | FileCheck %s +# XFAIL: * +0x46 0x2f 0x79 0x32 # CHECK : c.eq.d $fcc1, $f15, $f15 +0x46 0x11 0xc5 0x32 # CHECK : c.eq.s $fcc5, $f24, $f17 +0x46 0x35 0x5c 0x30 # CHECK : c.f.d $fcc4, $f11, $f21 +0x46 0x07 0xf4 0x30 # CHECK : c.f.s $fcc4, $f30, $f7 +0x46 0x21 0x94 0x3e # CHECK : c.le.d $fcc4, $f18, $f1 +0x46 0x04 0xc6 0x3e # CHECK : c.le.s $fcc6, $f24, $f4 +0x46 0x23 0x4b 0x3c # CHECK : c.lt.d $fcc3, $f9, $f3 +0x46 0x0e 0x8a 0x3c # CHECK : c.lt.s $fcc2, $f17, $f14 +0x46 0x30 0xad 0x3d # CHECK : c.nge.d $fcc5, $f21, $f16 +0x46 0x08 0x5b 0x3d # CHECK : c.nge.s $fcc3, $f11, $f8 +0x46 0x17 0xfa 0x3b # CHECK : c.ngl.s $fcc2, $f31, $f23 +0x46 0x17 0x92 0x39 # CHECK : c.ngle.s $fcc2, $f18, $f23 +0x46 0x27 0xc4 0x3f # CHECK : c.ngt.d $fcc4, $f24, $f7 +0x46 0x0d 0x45 0x3f # CHECK : c.ngt.s $fcc5, $f8, $f13 +0x46 0x3f 0x82 0x36 # CHECK : c.ole.d $fcc2, $f16, $f31 +0x46 0x14 0x3b 0x36 # CHECK : c.ole.s $fcc3, $f7, $f20 +0x46 0x3c 0x9c 0x34 # CHECK : c.olt.d $fcc4, $f19, $f28 +0x46 0x07 0xa6 0x34 # CHECK : c.olt.s $fcc6, $f20, $f7 +0x46 0x27 0xfc 0x3a # CHECK : c.seq.d $fcc4, $f31, $f7 +0x46 0x19 0x0f 0x3a # CHECK : c.seq.s $fcc7, $f1, $f25 +0x46 0x39 0x6c 0x33 # CHECK : c.ueq.d $fcc4, $f13, $f25 +0x46 0x1e 0x1e 0x33 # CHECK : c.ueq.s $fcc6, $f3, $f30 +0x46 0x32 0xcf 0x37 # CHECK : c.ule.d $fcc7, $f25, $f18 +0x46 0x1e 0xaf 0x37 # CHECK : c.ule.s $fcc7, $f21, $f30 +0x46 0x31 0x36 0x35 # CHECK : c.ult.d $fcc6, $f6, $f17 +0x46 0x0a 0xc7 0x35 # CHECK : c.ult.s $fcc7, $f24, $f10 +0x46 0x38 0xbe 0x31 # CHECK : c.un.d $fcc6, $f23, $f24 +0x46 0x04 0xf1 0x31 # CHECK : c.un.s $fcc1, $f30, $f4 +0x46 0xc0 0x45 0x85 # CHECK : abs.ps $f22, $f8 +0x46 0xcd 0xde 0x40 # CHECK : add.ps $f25, $f27, $f13 +0x4d 0x9e 0x93 0x1e # CHECK : alnv.ps $f12, $f18, $f30, $8 +0x46 0xc9 0x05 0x32 # CHECK : c.eq.ps $fcc5, $f0, $f9 +0x46 0xcb 0x5e 0x30 # CHECK : c.f.ps $fcc6, $f11, $f11 +0x46 0xd4 0x39 0x3e # CHECK : c.le.ps $fcc1, $f7, $f20 +0x46 0xc5 0x98 0x3c # CHECK : c.lt.ps $f19, $f5 +0x46 0xda 0x08 0x3d # CHECK : c.nge.ps $f1, $f26 +0x46 0xde 0xa8 0x3b # CHECK : c.ngl.ps $f21, $f30 +0x46 0xd4 0x67 0x39 # CHECK : c.ngle.ps $fcc7, $f12, $f20 +0x46 0xc6 0xf5 0x3f # CHECK : c.ngt.ps $fcc5, $f30, $f6 +0x46 0xc8 0xaf 0x36 # CHECK : c.ole.ps $fcc7, $f21, $f8 +0x46 0xd0 0x3b 0x34 # CHECK : c.olt.ps $fcc3, $f7,$ f16 +0x46 0xce 0xfe 0x3a # CHECK : c.seq.ps $fcc6, $f31, $f14 +0x46 0xc6 0x26 0x38 # CHECK : c.sf.ps $fcc6, $f4, $f6 +0x46 0xdd 0x29 0x33 # CHECK : c.ueq.ps $fcc1, $f5, $f29 +0x46 0xc3 0x8e 0x37 # CHECK : c.ule.ps $fcc6, $f17, $f3 +0x46 0xc0 0x77 0x35 # CHECK : c.ult.ps $fcc7, $f14, $f0 +0x46 0xda 0x14 0x31 # CHECK : c.un.ps $fcc4, $f2, $f26 +0x46 0x13 0x90 0xe6 # CHECK : cvt.ps.s $f3, $f18, $f19 +0x46 0xc0 0x0f 0xa8 # CHECK : cvt.s.pl $f30, $f1 +0x46 0xc0 0xcb 0xa0 # CHECK : cvt.s.pu $f14, $f25 +0x4e 0x74 0xd4 0xa1 # CHECK : madd.d $f18, $f19,$f26,$f20 +0x4c 0x63 0x75 0xa6 # CHECK : madd.ps $f22, $f3,$f14,$f3 +0x4f 0xf9 0x98 0x60 # CHECK : madd.s $f1, $f31,$f19,$f25 +0x46 0xc0 0x8d 0x86 # CHECK : mov.ps $f22, $f17 +0x46 0xd8 0xe2 0x91 # CHECK : movf.ps $f10, $f28,$fcc6 +0x46 0xd3 0xff 0xd3 # CHECK : movn.ps $f31, $f31, $19 +0x46 0xc9 0xcd 0x11 # CHECK : movt.ps $f20, $f25, $fcc2 +0x46 0xdf 0x8c 0x92 # CHECK : movz.ps $f18, $f17,ra +0x4c 0x32 0xfa 0xa9 # CHECK : msub.d $f10, $f1, $f31, $f18 +0x4d 0xd1 0xeb 0x2e # CHECK : msub.ps $f12, $f14, $f29, $f17 +0x4e 0x70 0x53 0x28 # CHECK : msub.s $f12, $f19, $f10, $f16 +0x46 0xd0 0x03 0x82 # CHECK : mul.ps $f14, $f0, $f16 +0x46 0xc0 0x6c 0xc7 # CHECK : neg.ps $f19, $f13 +0x4d 0x33 0x74 0xb1 # CHECK : nmadd.d $f18, $f9, $f14, $f19 +0x4c 0x99 0x4e 0xf6 # CHECK : nmadd.ps $f27, $f4, $f9, $f25 +0x4c 0xac 0xc8 0x30 # CHECK : nmadd.s $f0,$f5,$f25,$f12 +0x4d 0x1e 0x87 0xb9 # CHECK : nmsub.d $f30,$f8,$f16,$f30 +0x4d 0x91 0x71 0xbe # CHECK : nmsub.ps $f6, $f12, $f14, $f17 +0x4f 0x04 0x98 0x78 # CHECK : nmsub.s $f1, $f24, $f19, $f4 +0x46 0xde 0x4e 0x6c # CHECK : pll.ps $f25, $f9, $f30 +0x46 0xdd 0xd0 0x6d # CHECK : plu.ps $f1, $f26, $f29 +0x46 0xda 0xf2 0x6e # CHECK : pul.ps $f9, $f30, $f26 +0x46 0xc2 0x4e 0x2f # CHECK : puu.ps $f24, $f9, $f2 +0x46 0x20 0x34 0xd5 # CHECK : recip.d $f19, $f6 +0x46 0x00 0xf0 0xd5 # CHECK : recip.s $f3, $f30 +0x46 0x20 0xe0 0xd6 # CHECK : rsqrt.d $f3, $f28 +0x46 0x00 0x41 0x16 # CHECK : rsqrt.s $f4, $f8 +0x46 0xda 0x71 0x41 # CHECK : sub.ps $f5, $f14, $f26 diff --git a/llvm/test/MC/Disassembler/Mips/mips64/valid-mips64.txt b/llvm/test/MC/Disassembler/Mips/mips64/valid-mips64.txt new file mode 100644 index 0000000..26c49f1 --- /dev/null +++ b/llvm/test/MC/Disassembler/Mips/mips64/valid-mips64.txt @@ -0,0 +1,428 @@ +# RUN: llvm-mc --disassemble %s -triple=mips64-unknown-linux | FileCheck %s + +0x46 0x20 0x73 0x05 #CHECK: abs.d $f12, $f14 + +0x46 0x00 0x39 0x85 #CHECK: abs.s $f6, $f7 + +0x00 0xc7 0x48 0x20 #CHECK: add $9, $6, $7 + +0x46 0x2e 0x62 0x00 #CHECK: add.d $f8, $f12, $f14 + +0x46 0x07 0x32 0x40 #CHECK: add.s $f9, $f6, $f7 + +0x20 0xc9 0x45 0x67 #CHECK: addi $9, $6, 17767 + +0x24 0xc9 0xc5 0x67 #CHECK: addiu $9, $6, -15001 + +0x00 0xc7 0x48 0x21 #CHECK: addu $9, $6, $7 + +0x00 0xc7 0x48 0x24 #CHECK: and $9, $6, $7 + +0x30 0xc9 0x45 0x67 #CHECK: andi $9, $6, 17767 + +0x10 0x00 0x01 0x4c #CHECK: b 1332 + +0x45 0x00 0x01 0x4c #CHECK: bc1f 1332 + +0x45 0x1c 0x01 0x4c #CHECK: bc1f $fcc7, 1332 + +0x45 0x01 0x01 0x4c #CHECK: bc1t 1332 + +0x45 0x1d 0x01 0x4c #CHECK: bc1t $fcc7, 1332 + +0x11 0x26 0x01 0x4c #CHECK: beq $9, $6, 1332 + +0x04 0xc1 0x01 0x4c #CHECK: bgez $6, 1332 + +0x04 0xd1 0x01 0x4c #CHECK: bgezal $6, 1332 + +0x1c 0xc0 0x01 0x4c #CHECK: bgtz $6, 1332 + +0x18 0xc0 0x01 0x4c #CHECK: blez $6, 1332 + +0x15 0x26 0x01 0x4c #CHECK: bne $9, $6, 1332 + +0x46 0x2e 0x60 0x32 #CHECK: c.eq.d $f12, $f14 + +0x46 0x07 0x30 0x32 #CHECK: c.eq.s $f6, $f7 + +0x46 0x2e 0x60 0x30 #CHECK: c.f.d $f12, $f14 + +0x46 0x07 0x30 0x30 #CHECK: c.f.s $f6, $f7 + +0x46 0x2e 0x60 0x3e #CHECK: c.le.d $f12, $f14 + +0x46 0x07 0x30 0x3e #CHECK: c.le.s $f6, $f7 + +0x46 0x2e 0x60 0x3c #CHECK: c.lt.d $f12, $f14 + +0x46 0x07 0x30 0x3c #CHECK: c.lt.s $f6, $f7 + +0x46 0x2e 0x60 0x3d #CHECK: c.nge.d $f12, $f14 + +0x46 0x07 0x30 0x3d #CHECK: c.nge.s $f6, $f7 + +0x46 0x2e 0x60 0x3b #CHECK: c.ngl.d $f12, $f14 + +0x46 0x07 0x30 0x3b #CHECK: c.ngl.s $f6, $f7 + +0x46 0x2e 0x60 0x39 #CHECK: c.ngle.d $f12, $f14 + +0x46 0x07 0x30 0x39 #CHECK: c.ngle.s $f6, $f7 + +0x46 0x2e 0x60 0x3f #CHECK: c.ngt.d $f12, $f14 + +0x46 0x07 0x30 0x3f #CHECK: c.ngt.s $f6, $f7 + +0x46 0x2e 0x60 0x36 #CHECK: c.ole.d $f12, $f14 + +0x46 0x07 0x30 0x36 #CHECK: c.ole.s $f6, $f7 + +0x46 0x2e 0x60 0x34 #CHECK: c.olt.d $f12, $f14 + +0x46 0x07 0x30 0x34 #CHECK: c.olt.s $f6, $f7 + +0x46 0x2e 0x60 0x3a #CHECK: c.seq.d $f12, $f14 + +0x46 0x07 0x30 0x3a #CHECK: c.seq.s $f6, $f7 + +0x46 0x2e 0x60 0x38 #CHECK: c.sf.d $f12, $f14 + +0x46 0x07 0x30 0x38 #CHECK: c.sf.s $f6, $f7 + +0x46 0x2e 0x60 0x33 #CHECK: c.ueq.d $f12, $f14 + +0x46 0x12 0xe0 0x33 #CHECK: c.ueq.s $f28, $f18 + +0x46 0x2e 0x60 0x37 #CHECK: c.ule.d $f12, $f14 + +0x46 0x07 0x30 0x37 #CHECK: c.ule.s $f6, $f7 + +0x46 0x2e 0x60 0x35 #CHECK: c.ult.d $f12, $f14 + +0x46 0x07 0x30 0x35 #CHECK: c.ult.s $f6, $f7 + +0x46 0x2e 0x60 0x31 #CHECK: c.un.d $f12, $f14 + +0x46 0x07 0x30 0x31 #CHECK: c.un.s $f6, $f7 + +0x46 0x20 0x73 0x0e #CHECK: ceil.w.d $f12, $f14 + +0x46 0x00 0x39 0x8e #CHECK: ceil.w.s $f6, $f7 + +0x46 0x20 0x18 0x4a #CHECK: ceil.l.d $f1, $f3 + +0x46 0x00 0x6c 0x8a #CHECK: ceil.l.s $f18, $f13 + +0x44 0x46 0x38 0x00 #CHECK: cfc1 $6, $7 + +0x70 0xe6 0x30 0x21 #CHECK: clo $6, $7 + +0x70 0xe6 0x30 0x20 #CHECK: clz $6, $7 + +0x44 0xc6 0x38 0x00 #CHECK: ctc1 $6, $7 + +0x46 0x00 0x39 0xa1 #CHECK: cvt.d.s $f6, $f7 + +0x46 0xa0 0x81 0x21 #CHECK: cvt.d.l $f4, $f16 + +0x46 0x80 0x73 0x21 #CHECK: cvt.d.w $f12, $f14 + +0x46 0x20 0x73 0x20 #CHECK: cvt.s.d $f12, $f14 + +0x46 0xa0 0xf3 0xe0 #CHECK: cvt.s.l $f15, $f30 + +0x46 0x80 0x39 0xa0 #CHECK: cvt.s.w $f6, $f7 + +0x46 0x20 0x73 0x24 #CHECK: cvt.w.d $f12, $f14 + +0x46 0x00 0x39 0xa4 #CHECK: cvt.w.s $f6, $f7 + +0x00 0x3f 0x98 0x2c #CHECK: dadd $19, $1, $ra + +0x62 0x9d 0x93 0xc7 #CHECK: daddi $sp, $20, -27705 + +0x63 0xbd 0x93 0xc7 #CHECK: daddi $sp, $sp, -27705 + +0x62 0x9d 0x93 0xc7 #CHECK: daddi $sp, $20, -27705 + +0x62 0x9d 0x93 0xc7 #CHECK: daddi $sp, $20, -27705 + +0x63 0xbd 0x93 0xc7 #CHECK: daddi $sp, $sp, -27705 + +0x66 0xda 0xee 0x16 #CHECK: daddiu $26, $22, -4586 + +0x00 0x3f 0x98 0x2d #CHECK: daddu $19, $1, $ra + +0x64 0x58 0x46 0x9f #CHECK: daddiu $24, $2, 18079 + +0x66 0x73 0x69 0x3f #CHECK: daddiu $19, $19, 26943 + +0x70 0xd2 0x90 0x25 #CHECK: dclo $18, $6 + +0x73 0x30 0x80 0x24 #CHECK: dclz $16, $25 + +0x03 0x53 0x00 0x1e #CHECK: ddiv $zero, $26, $19 + +0x02 0x11 0x00 0x1f #CHECK: ddivu $zero, $16, $17 + +0x44 0x2c 0x68 0x00 #CHECK: dmfc1 $12, $f13 + +0x44 0xb0 0x70 0x00 #CHECK: dmtc1 $16, $f14 + +0x02 0xe9 0x00 0x1c #CHECK: dmult $23, $9 + +0x00 0xa6 0x00 0x1d #CHECK: dmultu $5, $6 + +0x00 0x00 0x04 0xb8 #CHECK: dsll $zero, $zero, 18 + +0x00 0x14 0x04 0xb8 #CHECK: dsll $zero, $20, 18 + +0x01 0x94 0x00 0x14 #CHECK: dsllv $zero, $20, $12 + +0x00 0x00 0x04 0xbc #CHECK: dsll32 $zero, $zero, 18 + +0x00 0x00 0x04 0xbc #CHECK: dsll32 $zero, $zero, 18 + +0x01 0x94 0x00 0x14 #CHECK: dsllv $zero, $20, $12 + +0x00 0x1c 0xe2 0xbb #CHECK: dsra $gp, $gp, 10 + +0x00 0x12 0xe2 0xbb #CHECK: dsra $gp, $18, 10 + +0x02 0x72 0xe0 0x17 #CHECK: dsrav $gp, $18, $19 + +0x00 0x1c 0xe2 0xbf #CHECK: dsra32 $gp, $gp, 10 + +0x00 0x12 0xe2 0xbf #CHECK: dsra32 $gp, $18, 10 + +0x02 0x72 0xe0 0x17 #CHECK: dsrav $gp, $18, $19 + +0x00 0x13 0x9d 0xfa #CHECK: dsrl $19, $19, 23 + +0x00 0x06 0x9d 0xfa #CHECK: dsrl $19, $6, 23 + +0x02 0x86 0x98 0x16 #CHECK: dsrlv $19, $6, $20 + +0x00 0x13 0x9d 0xfe #CHECK: dsrl32 $19, $19, 23 + +0x00 0x06 0x9d 0xfe #CHECK: dsrl32 $19, $6, 23 + +0x02 0x86 0x98 0x16 #CHECK: dsrlv $19, $6, $20 + +0x02 0xc8 0x38 0x2e #CHECK: dsub $7, $22, $8 + +0x62 0x9d 0x6c 0x39 #CHECK: daddi $sp, $20, 27705 + +0x63 0xbd 0x6c 0x39 #CHECK: daddi $sp, $sp, 27705 + +0x00 0xba 0x28 0x2f #CHECK: dsubu $5, $5, $26 + +0x65 0x6f 0xec 0x5f #CHECK: daddiu $15, $11, -5025 + +0x65 0xce 0x11 0xea #CHECK: daddiu $14, $14, 4586 + +0x46 0x20 0x3e 0x8b #CHECK: floor.l.d $f26, $f7 + +0x46 0x00 0x2b 0x0b #CHECK: floor.l.s $f12, $f5 + +0x46 0x20 0x73 0x0f #CHECK: floor.w.d $f12, $f14 + +0x46 0x00 0x39 0x8f #CHECK: floor.w.s $f6, $f7 + +0x08 0x00 0x01 0x4c #CHECK: j 1328 + +0x0c 0x00 0x01 0x4c #CHECK: jal 1328 + +0x74 0x00 0x01 0x4c #CHECK: jalx 1328 + +0x00 0xe0 0xf8 0x09 #CHECK: jalr $7 + +0x00 0x80 0xfc 0x09 #CHECK: jalr.hb $4 + +0x00 0xa0 0x24 0x09 #CHECK: jalr.hb $4, $5 + +0x00 0xe0 0x00 0x08 #CHECK: jr $7 + +0x80 0xa4 0x23 0xc6 #CHECK: lb $4, 9158($5) + +0x90 0xa4 0x00 0x06 #CHECK: lbu $4, 6($5) + +0xd4 0xe9 0x23 0xc6 #CHECK: ldc1 $f9, 9158($7) + +0xde 0x3d 0x90 0x1b #CHECK: ld $sp, -28645($17) + +0x6b 0x18 0xef 0xb9 #CHECK: ldl $24, -4167($24) + +0x6e 0x8e 0x89 0x6a #CHECK: ldr $14, -30358($20) + +0x4d 0xf7 0x02 0x01 #CHECK: ldxc1 $f8, $23($15) + +0x84 0xa4 0x00 0x0c #CHECK: lh $4, 12($5) + +0x84 0xa4 0x00 0x0c #CHECK: lh $4, 12($5) + +0xc0 0xe9 0x23 0xc6 #CHECK: ll $9, 9158($7) + +0xd3 0xe0 0xc6 0x70 #CHECK: lld $zero, -14736($ra) + +0x3c 0x06 0x45 0x67 #CHECK: lui $6, 17767 + +0x4e 0xb6 0x04 0xc5 #CHECK: luxc1 $f19, $22($21) + +0x9c 0x73 0xa1 0xea #CHECK: lwu $19, -24086($3) + +0x4f 0xd1 0x03 0x00 #CHECK: lwxc1 $f12, $17($fp) + +0x8c 0xa4 0x00 0x18 #CHECK: lw $4, 24($5) + +0xc4 0xe9 0x23 0xc6 #CHECK: lwc1 $f9, 9158($7) + +0x88 0x82 0x00 0x03 #CHECK: lwl $2, 3($4) + +0x98 0xa3 0x00 0x10 #CHECK: lwr $3, 16($5) + +0x70 0xc7 0x00 0x00 #CHECK: madd $6, $7 + +0x70 0xc7 0x00 0x01 #CHECK: maddu $6, $7 + +0x44 0x06 0x38 0x00 #CHECK: mfc1 $6, $f7 + +0x00 0x00 0x28 0x10 #CHECK: mfhi $5 + +0x00 0x00 0x28 0x12 #CHECK: mflo $5 + +0x46 0x20 0x41 0x86 #CHECK: mov.d $f6, $f8 + +0x46 0x00 0x39 0x86 #CHECK: mov.s $f6, $f7 + +0x70 0xc7 0x00 0x04 #CHECK: msub $6, $7 + +0x70 0xc7 0x00 0x05 #CHECK: msubu $6, $7 + +0x44 0x86 0x38 0x00 #CHECK: mtc1 $6, $f7 + +0x00 0xe0 0x00 0x11 #CHECK: mthi $7 + +0x00 0xe0 0x00 0x13 #CHECK: mtlo $7 + +0x46 0x2e 0x62 0x02 #CHECK: mul.d $f8, $f12, $f14 + +0x46 0x07 0x32 0x42 #CHECK: mul.s $f9, $f6, $f7 + +0x70 0xc7 0x48 0x02 #CHECK: mul $9, $6, $7 + +0x00 0x65 0x00 0x18 #CHECK: mult $3, $5 + +0x00 0x65 0x00 0x19 #CHECK: multu $3, $5 + +0x46 0x20 0x73 0x07 #CHECK: neg.d $f12, $f14 + +0x46 0x00 0x39 0x87 #CHECK: neg.s $f6, $f7 + +0x00 0x00 0x00 0x00 #CHECK: nop + +0x00 0xc7 0x48 0x27 #CHECK: nor $9, $6, $7 + +0x00 0x65 0x18 0x25 #CHECK: or $3, $3, $5 + +0x34 0xc9 0x45 0x67 #CHECK: ori $9, $6, 17767 + +0x46 0x20 0x0b 0x08 #CHECK: round.l.d $f12, $f1 + +0x46 0x00 0x2e 0x48 #CHECK: round.l.s $f25, $f5 + +0x46 0x20 0x73 0x0c #CHECK: round.w.d $f12, $f14 + +0x46 0x00 0x39 0x8c #CHECK: round.w.s $f6, $f7 + +0xa0 0xa4 0x23 0xc6 #CHECK: sb $4, 9158($5) + +0xa0 0xa4 0x00 0x06 #CHECK: sb $4, 6($5) + +0xe0 0xe9 0x23 0xc6 #CHECK: sc $9, 9158($7) + +0xf3 0xaf 0xdf 0xcd #CHECK: scd $15, -8243($sp) + +0xfd 0x4c 0x16 0xcb #CHECK: sd $12, 5835($10) + +0xf4 0xe9 0x23 0xc6 #CHECK: sdc1 $f9, 9158($7) + +0xb3 0xc7 0xae 0x1f #CHECK: sdl $7, -20961($fp) + +0xb5 0x8b 0xb0 0x39 #CHECK: sdr $11, -20423($12) + +0x4d 0xca 0x58 0x09 #CHECK: sdxc1 $f11, $10($14) + +0xa4 0xa4 0x23 0xc6 #CHECK: sh $4, 9158($5) + +0x00 0x03 0x21 0xc0 #CHECK: sll $4, $3, 7 + +0x00 0xa3 0x10 0x04 #CHECK: sllv $2, $3, $5 + +0x00 0x65 0x18 0x2a #CHECK: slt $3, $3, $5 + +0x28 0x63 0x00 0x67 #CHECK: slti $3, $3, 103 + +0x2c 0x63 0x00 0x67 #CHECK: sltiu $3, $3, 103 + +0x00 0x65 0x18 0x2b #CHECK: sltu $3, $3, $5 + +0x46 0x20 0x73 0x04 #CHECK: sqrt.d $f12, $f14 + +0x46 0x00 0x39 0x84 #CHECK: sqrt.s $f6, $f7 + +0x00 0x03 0x21 0xc3 #CHECK: sra $4, $3, 7 + +0x00 0xa3 0x10 0x07 #CHECK: srav $2, $3, $5 + +0x00 0x03 0x21 0xc2 #CHECK: srl $4, $3, 7 + +0x00 0xa3 0x10 0x06 #CHECK: srlv $2, $3, $5 + +0x46 0x2e 0x62 0x01 #CHECK: sub.d $f8, $f12, $f14 + +0x46 0x07 0x32 0x41 #CHECK: sub.s $f9, $f6, $f7 + +0x00 0xc7 0x48 0x22 #CHECK: sub $9, $6, $7 + +0x00 0x65 0x20 0x23 #CHECK: subu $4, $3, $5 + +0xac 0xa4 0x00 0x18 #CHECK: sw $4, 24($5) + +0xe4 0xe9 0x23 0xc6 #CHECK: swc1 $f9, 9158($7) + +0x4d 0xbb 0x60 0x0d #CHECK: suxc1 $f12, $27($13) + +0x4f 0x4c 0x98 0x08 #CHECK: swxc1 $f19, $12($26) + +0xa8 0xa4 0x00 0x10 #CHECK: swl $4, 16($5) + +0xb8 0xe6 0x00 0x10 #CHECK: swr $6, 16($7) + +0x00 0x00 0x01 0xcf #CHECK: sync 7 + +0x46 0x20 0xbd 0xc9 #CHECK: trunc.l.d $f23, $f23 + +0x46 0x00 0xff 0x09 #CHECK: trunc.l.s $f28, $f31 + +0x46 0x20 0x73 0x0d #CHECK: trunc.w.d $f12, $f14 + +0x46 0x00 0x39 0x8d #CHECK: trunc.w.s $f6, $f7 + +0x00 0x65 0x18 0x26 #CHECK: xor $3, $3, $5 + +0x38 0xc9 0x45 0x67 #CHECK: xori $9, $6, 17767 + +0x7c 0x05 0xe8 0x3b #CHECK: .set push + #CHECK: .set mips32r2 + #CHECK: rdhwr $5, $29 + #CHECK: .set pop + +0xbc 0x61 0x00 0x02 #CHECK: cache 1, 2($3) + +0xcc 0x43 0x00 0x04 #CHECK: pref 3, 4($2) + +0xe8 0xe9 0x23 0xc6 #CHECK: swc2 $9, 9158($7) + +0xc8 0xc8 0x23 0xca #CHECK: lwc2 $8, 9162($6)