#include <stdio.h>
#define TESTINST1(instruction, RSval, RTval, RD, RS, RT) \
{ \
unsigned int out; \
__asm__ volatile( \
"li $" #RD ", 0\n\t" \
"move $" #RS ", %1\n\t" \
"move $" #RT ", %2\n\t" \
instruction "\n\t" \
"move %0, $" #RD "\n\t" \
: "=&r" (out) \
: "r" (RSval), "r" (RTval) \
: #RD, #RS, #RT, "cc", "memory" \
); \
printf("%s :: rd 0x%08x rs 0x%08x, rt 0x%08x\n", \
instruction, out, RSval, RTval); \
}
#define TESTINST2(instruction, RSval, imm, RT, RS) \
{ \
unsigned int out; \
__asm__ volatile( \
"move $" #RS ", %1\n\t" \
instruction "\n\t" \
"move %0, $" #RT "\n\t" \
: "=&r" (out) \
: "r" (RSval) \
: #RT, #RS, "cc", "memory" \
); \
printf("%s :: rt 0x%08x rs 0x%08x, imm 0x%08x\n", \
instruction, out, RSval, imm); \
}
#define TESTINST3(instruction, RSval, RD, RS) \
{ \
unsigned int out; \
__asm__ volatile( \
"move $" #RS ", %1\n\t" \
instruction "\n\t" \
"move %0, $" #RD "\n\t" \
: "=&r" (out) \
: "r" (RSval) \
: #RD, #RS, "cc", "memory" \
); \
printf("%s :: rd 0x%08x rs 0x%08x\n", \
instruction, out, RSval); \
}
#define TESTINST3a(instruction, RSval, RTval, RS, RT) \
{ \
unsigned int HI; \
unsigned int LO; \
__asm__ volatile( \
"li $" #RS ", 0x0\n\t" \
"mthi $" #RS"\n\t" \
"mtlo $" #RS"\n\t" \
"move $" #RS ", %2\n\t" \
"move $" #RT ", %3\n\t" \
instruction "\n\t" \
"mfhi %0 \n\t" \
"mflo %1 \n\t" \
: "=&r" (HI), "=&r" (LO) \
: "r" (RSval), "r"(RTval) \
: #RS, #RT, "cc", "memory" \
); \
printf("%s :: rs 0x%08x rt 0x%08x HI 0x%08x LO 0x%08x \n", \
instruction, RSval, RTval, HI, LO); \
}
#define TESTINST4(instruction, RTval, RSval, RT, RS, pos, size) \
{ \
unsigned int out; \
__asm__ volatile( \
"move $" #RT ", %1\n\t" \
"move $" #RS ", %2\n\t" \
instruction "\n\t" \
"move %0, $" #RT "\n\t" \
: "=&r" (out) \
: "r" (RTval), "r" (RSval) \
: #RT, #RS, "cc", "memory" \
); \
printf("%s :: rt 0x%08x rs 0x%08x, pos 0x%08x, size 0x%08x\n", \
instruction, out, RSval, pos, size); \
}
const unsigned int mem[] = {
0x121f1e1f, 0, 3, -1,
0x232f2e2f, 0x242c2b2b, 0x252a2e2b, 0x262d2d2a,
0x3f343f3e, 0x3e353d3c, 0x363a3c3b, 0x3b373b3a,
0x454f4e45, 0x4e464d46, 0x474d474c, 0x4a484a4c
};
// load $t0, 0($t1)
#define TESTINSN5LOAD(instruction, RTval, offset, RT) \
{ \
unsigned int out; \
__asm__ volatile( \
"move $t1, %1\n\t" \
"li $t0, " #RTval"\n\t" \
instruction "\n\t" \
"move %0, $" #RT "\n\t" \
: "=&r" (out) \
: "r" (mem), "r" (RTval) \
: #RT, "cc", "memory" \
); \
printf("%s :: rt 0x%08x\n", \
instruction, out); \
}
#define TESTINSN_HILO(RSval) \
{ \
unsigned int HI; \
unsigned int LO; \
__asm__ volatile( \
"move $t0, %2\n\t" \
"mthi $t0\n\t" \
"addiu $t0, $t0, 0xffff\n\t" \
"mtlo $t0\n\t" \
"mfhi %0\n\t" \
"mflo %1\n\t" \
: "=&r" (HI), "=&r" (LO) \
: "r" (RSval)\
: "cc", "memory" \
); \
printf("mfhi mflo :: HI: 0x%x, LO: 0x%x\n", \
HI, LO); \
}
int main(int argc, char **argv)
{
printf("ADD\n");
TESTINST1("add $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("add $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("add $t0, $t1, $t2", 1, 0, t0, t1, t2);
TESTINST1("add $t0, $t1, $t2", 1, 1, t0, t1, t2);
TESTINST1("add $t0, $t1, $t2", 0, -1, t0, t1, t2);
TESTINST1("add $t0, $t1, $t2", 1, -1, t0, t1, t2);
TESTINST1("add $t0, $t1, $t2", 0x80000000, 0, t0, t1, t2);
TESTINST1("add $t0, $t1, $t2", 0x31415927, 0x27181728, t0, t1, t2);
TESTINST1("add $t0, $t1, $t2", 0x31415927, 0x97181728, t0, t1, t2);
TESTINST1("add $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("add $t0, $t1, $t2", 0, 0x80000000, t0, t1, t2);
TESTINST1("add $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
printf("ADDI\n");
TESTINST2("addi $t0, $t1, 0", 0, 0, t0, t1);
TESTINST2("addi $t0, $t1, 1", 0, 1, t0, t1);
TESTINST2("addi $t0, $t1, 1", 1, 0, t0, t1);
TESTINST2("addi $t0, $t1, 1", 1, 1, t0, t1);
TESTINST2("addi $t0, $t1, -1", 0, -1, t0, t1);
TESTINST2("addi $t0, $t1, -1", 1, -1, t0, t1);
TESTINST2("addi $t0, $t1, 0", 0x80000000, 0, t0, t1);
TESTINST2("addi $t0, $t1, 0", -1, 0, t0, t1);
TESTINST2("addi $t0, $t1, 0", 0x80000000, 0, t0, t1);
printf("ADDIU\n");
TESTINST2("addiu $t0, $t1, 0", 0, 0, t0, t1);
TESTINST2("addiu $t0, $t1, 1", 0, 1, t0, t1);
TESTINST2("addiu $t0, $t1, 1", 1, 0, t0, t1);
TESTINST2("addiu $t0, $t1, 1", 1, 1, t0, t1);
TESTINST2("addiu $t0, $t1, -1", 0, -1, t0, t1);
TESTINST2("addiu $t0, $t1, -1", 1, -1, t0, t1);
TESTINST2("addiu $t0, $t1, 0", 0x80000000, 0, t0, t1);
TESTINST2("addiu $t0, $t1, 0", -1, 0, t0, t1);
TESTINST2("addiu $t0, $t1, 0", 0x80000000, 0, t0, t1);
printf("ADDU\n");
TESTINST1("addu $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("addu $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("addu $t0, $t1, $t2", 1, 0, t0, t1, t2);
TESTINST1("addu $t0, $t1, $t2", 1, 1, t0, t1, t2);
TESTINST1("addu $t0, $t1, $t2", 0, -1, t0, t1, t2);
TESTINST1("addu $t0, $t1, $t2", 1, -1, t0, t1, t2);
TESTINST1("addu $t0, $t1, $t2", 0x31415927, 0x27181728, t0, t1, t2);
TESTINST1("addu $t0, $t1, $t2", 0x31415927, 0x97181728, t0, t1, t2);
TESTINST1("addu $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("addu $t0, $t1, $t2", 1, 0, t0, t1, t2);
TESTINST1("addu $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("addu $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("addu $t0, $t1, $t2", 0, -1, t0, t1, t2);
TESTINST1("addu $t0, $t1, $t2", 0, 0x80000000, t0, t1, t2);
TESTINST1("addu $t0, $t1, $t2", 0x80000000, 0, t0, t1, t2);
TESTINST1("addu $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("addu $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("addu $t0, $t1, $t2", 0x80000000, 0x7fffffff, t0, t1, t2);
TESTINST1("addu $t0, $t1, $t2", 0x7fffffff, 0x7fffffff, t0, t1, t2);
printf("AND\n");
TESTINST1("and $t0, $t1, $t2", 0x31415927, 0xffffffff, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", 0x80000000, -1, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", 0x7fffffff, 0, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", 0x80000000, 0xff000000, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", 0x7fffffff, 0x0dd00000, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", 0x31415927, 0xffffffff, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", 1, 0, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", 0, -1, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", 0, 0x80000000, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", 0x80000000, 0, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", 0x80000000, 0xff000000, t0, t1, t2);
TESTINST1("and $t0, $t1, $t2", 0x7fffffff, 0x0dd00000, t0, t1, t2);
printf("ANDI\n");
TESTINST2("andi $t0, $t1, 1", 0, 1, t0, t1);
TESTINST2("andi $t0, $t1, 0", 1, 0, t0, t1);
TESTINST2("andi $t0, $t1, 1", 1, 1, t0, t1);
TESTINST2("andi $t0, $t1, 1", 0x7fffffff, 0, t0, t1);
TESTINST2("andi $t0, $t1, 0", 0x80000000, 0, t0, t1);
TESTINST2("andi $t0, $t1, 0x3145", 0xffffffff, 0x3145, t0, t1);
printf("CLO\n");
TESTINST3("clo $t0, $t1", 0, t0, t1);
TESTINST3("clo $t0, $t1", 1, t0, t1);
TESTINST3("clo $t0, $t1", 0x10, t0, t1);
TESTINST3("clo $t0, $t1", 0xffffffff, t0, t1);
printf("CLZ\n");
TESTINST3("clz $t0, $t1", 0, t0, t1);
TESTINST3("clz $t0, $t1", 1, t0, t1);
TESTINST3("clz $t0, $t1", 0x10, t0, t1);
TESTINST3("clz $t0, $t1", 0xffffffff, t0, t1);
printf("DIV\n");
TESTINST3a("div $t0, $t1", 0x6, 0x2, t0, t1);
TESTINST3a("div $t0, $t1", 0x7fffffff, 0x7fffffff, t0, t1);
TESTINST3a("div $t0, $t1", 0xffffffff, 0x1, t0, t1);
TESTINST3a("div $t0, $t1", 0x1, 0xffffffff, t0, t1);
TESTINST3a("div $t0, $t1", 0x2, 0x6, t0, t1);
printf("DIVU\n");
TESTINST3a("divu $t0, $t1", 0x6, 0x2, t0, t1);
TESTINST3a("divu $t0, $t1", 0x7fffffff, 0x7fffffff, t0, t1);
TESTINST3a("divu $t0, $t1", 0xffffffff, 0x1, t0, t1);
TESTINST3a("divu $t0, $t1", 0x1, 0xffffffff, t0, t1);
TESTINST3a("divu $t0, $t1", 0x2, 0x6, t0, t1);
TESTINST3a("divu $t0, $t1", 0x0, 0x2, t0, t1);
#if (__mips==32) && (__mips_isa_rev>=2)
printf("EXT\n");
TESTINST4("ext $t0, $t1, 2, 6", 0, 0xffffffff, t0, t1, 2, 6);
TESTINST4("ext $t0, $t1, 2, 6", 0xffffffff, 0xffffffff, t0, t1, 2, 6);
TESTINST4("ext $t0, $t1, 2, 6", 0, 0xffffffff, t0, t1, 31, 6);
TESTINST4("ext $t0, $t1, 2, 6", 0, 0, t0, t1, 32, 32);
TESTINST4("ext $t0, $t1, 2, 6", 0, 0xffff, t0, t1, 31, 0);
TESTINST4("ext $t0, $t1, 2, 6", 0, 0xff, t0, t1, 31, 0)
TESTINST4("ext $t0, $t1, 2, 6", 0, 0xf0000000, t0, t1, 31, 0)
TESTINST4("ext $t0, $t1, 2, 6", 0, 0xf0000000, t0, t1, 0, 31)
TESTINST4("ext $t0, $t1, 2, 6", 0, 0x31415927, t0, t1, 3, 25)
printf("INS\n");
TESTINST4("ins $t0, $t1, 2, 6", 0, 0xffffffff, t0, t1, 2, 6);
TESTINST4("ins $t0, $t1, 2, 6", 0xffffffff, 0xffffffff, t0, t1, 2, 6);
TESTINST4("ins $t0, $t1, 2, 6", 0, 0xffffffff, t0, t1, 31, 6);
TESTINST4("ins $t0, $t1, 2, 6", 0, 0, t0, t1, 32, 32);
TESTINST4("ins $t0, $t1, 2, 6", 0, 0xffff, t0, t1, 31, 0);
TESTINST4("ins $t0, $t1, 2, 6", 0, 0xff, t0, t1, 31, 0)
TESTINST4("ins $t0, $t1, 2, 6", 0, 0xf0000000, t0, t1, 31, 0)
TESTINST4("ins $t0, $t1, 2, 6", 0, 0xf0000000, t0, t1, 0, 31)
TESTINST4("ins $t0, $t1, 2, 6", 0, 0x31415927, t0, t1, 3, 25)
#endif
printf("LB\n");
TESTINSN5LOAD("lb $t0, 0($t1)", 0, 0, t0);
TESTINSN5LOAD("lb $t0, 4($t1)", 0, 4, t0);
TESTINSN5LOAD("lb $t0, 8($t1)", 0, 8, t0);
TESTINSN5LOAD("lb $t0, 12($t1)", 0, 12, t0);
TESTINSN5LOAD("lb $t0, 16($t1)", 0, 16, t0);
TESTINSN5LOAD("lb $t0, 20($t1)", 0, 20, t0);
TESTINSN5LOAD("lb $t0, 24($t1)", 0, 24, t0);
TESTINSN5LOAD("lb $t0, 28($t1)", 0, 28, t0);
TESTINSN5LOAD("lb $t0, 32($t1)", 0, 32, t0);
TESTINSN5LOAD("lb $t0, 36($t1)", 0, 36, t0);
TESTINSN5LOAD("lb $t0, 40($t1)", 0, 40, t0);
TESTINSN5LOAD("lb $t0, 44($t1)", 0, 44, t0);
TESTINSN5LOAD("lb $t0, 48($t1)", 0, 48, t0);
TESTINSN5LOAD("lb $t0, 52($t1)", 0, 52, t0);
TESTINSN5LOAD("lb $t0, 56($t1)", 0, 56, t0);
TESTINSN5LOAD("lb $t0, 60($t1)", 0, 60, t0);
TESTINSN5LOAD("lb $t0, 64($t1)", 0, 64, t0);
TESTINSN5LOAD("lb $t0, 2($t1)", 0, 2, t0);
TESTINSN5LOAD("lb $t0, 6($t1)", 0, 6, t0);
TESTINSN5LOAD("lb $t0, 10($t1)", 0, 10, t0);
TESTINSN5LOAD("lb $t0, 14($t1)", 0, 14, t0);
TESTINSN5LOAD("lb $t0, 18($t1)", 0, 18, t0);
TESTINSN5LOAD("lb $t0, 22($t1)", 0, 22, t0);
TESTINSN5LOAD("lb $t0, 26($t1)", 0, 26, t0);
TESTINSN5LOAD("lb $t0, 30($t1)", 0, 30, t0);
TESTINSN5LOAD("lb $t0, 34($t1)", 0, 34, t0);
TESTINSN5LOAD("lb $t0, 38($t1)", 0, 38, t0);
printf("LBU\n");
TESTINSN5LOAD("lbu $t0, 0($t1)", 0, 0, t0);
TESTINSN5LOAD("lbu $t0, 4($t1)", 0, 4, t0);
TESTINSN5LOAD("lbu $t0, 8($t1)", 0, 8, t0);
TESTINSN5LOAD("lbu $t0, 12($t1)", 0, 12, t0);
TESTINSN5LOAD("lbu $t0, 16($t1)", 0, 16, t0);
TESTINSN5LOAD("lbu $t0, 20($t1)", 0, 20, t0);
TESTINSN5LOAD("lbu $t0, 24($t1)", 0, 24, t0);
TESTINSN5LOAD("lbu $t0, 28($t1)", 0, 28, t0);
TESTINSN5LOAD("lbu $t0, 32($t1)", 0, 32, t0);
TESTINSN5LOAD("lbu $t0, 36($t1)", 0, 36, t0);
TESTINSN5LOAD("lbu $t0, 40($t1)", 0, 40, t0);
TESTINSN5LOAD("lbu $t0, 44($t1)", 0, 44, t0);
TESTINSN5LOAD("lbu $t0, 48($t1)", 0, 48, t0);
TESTINSN5LOAD("lbu $t0, 52($t1)", 0, 52, t0);
TESTINSN5LOAD("lbu $t0, 56($t1)", 0, 56, t0);
TESTINSN5LOAD("lbu $t0, 60($t1)", 0, 60, t0);
TESTINSN5LOAD("lbu $t0, 64($t1)", 0, 64, t0);
TESTINSN5LOAD("lbu $t0, 2($t1)", 0, 2, t0);
TESTINSN5LOAD("lbu $t0, 6($t1)", 0, 6, t0);
TESTINSN5LOAD("lbu $t0, 10($t1)", 0, 10, t0);
TESTINSN5LOAD("lbu $t0, 14($t1)", 0, 14, t0);
TESTINSN5LOAD("lbu $t0, 18($t1)", 0, 18, t0);
TESTINSN5LOAD("lbu $t0, 22($t1)", 0, 22, t0);
TESTINSN5LOAD("lbu $t0, 26($t1)", 0, 26, t0);
TESTINSN5LOAD("lbu $t0, 30($t1)", 0, 30, t0);
TESTINSN5LOAD("lbu $t0, 34($t1)", 0, 34, t0);
TESTINSN5LOAD("lbu $t0, 38($t1)", 0, 38, t0);
printf("LH\n");
TESTINSN5LOAD("lh $t0, 0($t1)", 0, 0, t0);
TESTINSN5LOAD("lh $t0, 4($t1)", 0, 4, t0);
TESTINSN5LOAD("lh $t0, 8($t1)", 0, 8, t0);
TESTINSN5LOAD("lh $t0, 12($t1)", 0, 12, t0);
TESTINSN5LOAD("lh $t0, 16($t1)", 0, 16, t0);
TESTINSN5LOAD("lh $t0, 20($t1)", 0, 20, t0);
TESTINSN5LOAD("lh $t0, 24($t1)", 0, 24, t0);
TESTINSN5LOAD("lh $t0, 28($t1)", 0, 28, t0);
TESTINSN5LOAD("lh $t0, 32($t1)", 0, 32, t0);
TESTINSN5LOAD("lh $t0, 36($t1)", 0, 36, t0);
TESTINSN5LOAD("lh $t0, 40($t1)", 0, 40, t0);
TESTINSN5LOAD("lh $t0, 44($t1)", 0, 44, t0);
TESTINSN5LOAD("lh $t0, 48($t1)", 0, 48, t0);
TESTINSN5LOAD("lh $t0, 52($t1)", 0, 52, t0);
TESTINSN5LOAD("lh $t0, 56($t1)", 0, 56, t0);
TESTINSN5LOAD("lh $t0, 60($t1)", 0, 60, t0);
TESTINSN5LOAD("lh $t0, 64($t1)", 0, 64, t0);
TESTINSN5LOAD("lh $t0, 2($t1)", 0, 2, t0);
TESTINSN5LOAD("lh $t0, 6($t1)", 0, 6, t0);
TESTINSN5LOAD("lh $t0, 10($t1)", 0, 10, t0);
TESTINSN5LOAD("lh $t0, 14($t1)", 0, 14, t0);
TESTINSN5LOAD("lh $t0, 18($t1)", 0, 18, t0);
TESTINSN5LOAD("lh $t0, 22($t1)", 0, 22, t0);
TESTINSN5LOAD("lh $t0, 26($t1)", 0, 26, t0);
TESTINSN5LOAD("lh $t0, 30($t1)", 0, 30, t0);
TESTINSN5LOAD("lh $t0, 34($t1)", 0, 34, t0);
TESTINSN5LOAD("lh $t0, 38($t1)", 0, 38, t0);
printf("LHU\n");
TESTINSN5LOAD("lhu $t0, 0($t1)", 0, 0, t0);
TESTINSN5LOAD("lhu $t0, 4($t1)", 0, 4, t0);
TESTINSN5LOAD("lhu $t0, 8($t1)", 0, 8, t0);
TESTINSN5LOAD("lhu $t0, 12($t1)", 0, 12, t0);
TESTINSN5LOAD("lhu $t0, 16($t1)", 0, 16, t0);
TESTINSN5LOAD("lhu $t0, 20($t1)", 0, 20, t0);
TESTINSN5LOAD("lhu $t0, 24($t1)", 0, 24, t0);
TESTINSN5LOAD("lhu $t0, 28($t1)", 0, 28, t0);
TESTINSN5LOAD("lhu $t0, 32($t1)", 0, 32, t0);
TESTINSN5LOAD("lhu $t0, 36($t1)", 0, 36, t0);
TESTINSN5LOAD("lhu $t0, 40($t1)", 0, 40, t0);
TESTINSN5LOAD("lhu $t0, 44($t1)", 0, 44, t0);
TESTINSN5LOAD("lhu $t0, 48($t1)", 0, 48, t0);
TESTINSN5LOAD("lhu $t0, 52($t1)", 0, 52, t0);
TESTINSN5LOAD("lhu $t0, 56($t1)", 0, 56, t0);
TESTINSN5LOAD("lhu $t0, 60($t1)", 0, 60, t0);
TESTINSN5LOAD("lhu $t0, 64($t1)", 0, 64, t0);
TESTINSN5LOAD("lhu $t0, 2($t1)", 0, 2, t0);
TESTINSN5LOAD("lhu $t0, 6($t1)", 0, 6, t0);
TESTINSN5LOAD("lhu $t0, 10($t1)", 0, 10, t0);
TESTINSN5LOAD("lhu $t0, 14($t1)", 0, 14, t0);
TESTINSN5LOAD("lhu $t0, 18($t1)", 0, 18, t0);
TESTINSN5LOAD("lhu $t0, 22($t1)", 0, 22, t0);
TESTINSN5LOAD("lhu $t0, 26($t1)", 0, 26, t0);
TESTINSN5LOAD("lhu $t0, 30($t1)", 0, 30, t0);
TESTINSN5LOAD("lhu $t0, 34($t1)", 0, 34, t0);
TESTINSN5LOAD("lhu $t0, 38($t1)", 0, 38, t0);
printf("LUI\n");
TESTINST3("lui $t0, 0xffff", 0xffff, t0, t1);
TESTINST3("lui $t0, 0xff00", 0xff00, t0, t1);
TESTINST3("lui $t0, 0xff", 0xff, t0, t1);
TESTINST3("lui $t0, 0x0", 0x0, t0, t1);
TESTINST3("lui $t0, 0x5", 0x5, t0, t1);
TESTINST3("lui $t0, 0x387", 0x387, t0, t1);
printf("LW\n");
TESTINSN5LOAD("lw $t0, 0($t1)", 0, 0, t0);
TESTINSN5LOAD("lw $t0, 4($t1)", 0, 4, t0);
TESTINSN5LOAD("lw $t0, 8($t1)", 0, 8, t0);
TESTINSN5LOAD("lw $t0, 12($t1)", 0, 12, t0);
TESTINSN5LOAD("lw $t0, 16($t1)", 0, 16, t0);
TESTINSN5LOAD("lw $t0, 20($t1)", 0, 20, t0);
TESTINSN5LOAD("lw $t0, 24($t1)", 0, 24, t0);
TESTINSN5LOAD("lw $t0, 28($t1)", 0, 28, t0);
TESTINSN5LOAD("lw $t0, 32($t1)", 0, 32, t0);
TESTINSN5LOAD("lw $t0, 36($t1)", 0, 36, t0);
TESTINSN5LOAD("lw $t0, 40($t1)", 0, 40, t0);
TESTINSN5LOAD("lw $t0, 44($t1)", 0, 44, t0);
TESTINSN5LOAD("lw $t0, 48($t1)", 0, 48, t0);
TESTINSN5LOAD("lw $t0, 52($t1)", 0, 52, t0);
TESTINSN5LOAD("lw $t0, 56($t1)", 0, 56, t0);
TESTINSN5LOAD("lw $t0, 60($t1)", 0, 60, t0);
TESTINSN5LOAD("lw $t0, 64($t1)", 0, 64, t0);
TESTINSN5LOAD("lw $t0, 2($t1)", 0, 2, t0);
TESTINSN5LOAD("lw $t0, 6($t1)", 0, 6, t0);
TESTINSN5LOAD("lw $t0, 10($t1)", 0, 10, t0);
TESTINSN5LOAD("lw $t0, 14($t1)", 0, 14, t0);
TESTINSN5LOAD("lw $t0, 18($t1)", 0, 18, t0);
TESTINSN5LOAD("lw $t0, 22($t1)", 0, 22, t0);
TESTINSN5LOAD("lw $t0, 26($t1)", 0, 26, t0);
TESTINSN5LOAD("lw $t0, 30($t1)", 0, 30, t0);
TESTINSN5LOAD("lw $t0, 34($t1)", 0, 34, t0);
TESTINSN5LOAD("lw $t0, 38($t1)", 0, 38, t0);
printf("LWL\n");
TESTINSN5LOAD("lwl $t0, 0($t1)", 0, 0, t0);
TESTINSN5LOAD("lwl $t0, 4($t1)", 0, 4, t0);
TESTINSN5LOAD("lwl $t0, 8($t1)", 0, 8, t0);
TESTINSN5LOAD("lwl $t0, 12($t1)", 0, 12, t0);
TESTINSN5LOAD("lwl $t0, 16($t1)", 0, 16, t0);
TESTINSN5LOAD("lwl $t0, 20($t1)", 0, 20, t0);
TESTINSN5LOAD("lwl $t0, 24($t1)", 0, 24, t0);
TESTINSN5LOAD("lwl $t0, 28($t1)", 0, 28, t0);
TESTINSN5LOAD("lwl $t0, 32($t1)", 0, 32, t0);
TESTINSN5LOAD("lwl $t0, 36($t1)", 0, 36, t0);
TESTINSN5LOAD("lwl $t0, 40($t1)", 0, 40, t0);
TESTINSN5LOAD("lwl $t0, 44($t1)", 0, 44, t0);
TESTINSN5LOAD("lwl $t0, 48($t1)", 0, 48, t0);
TESTINSN5LOAD("lwl $t0, 52($t1)", 0, 52, t0);
TESTINSN5LOAD("lwl $t0, 56($t1)", 0, 56, t0);
TESTINSN5LOAD("lwl $t0, 60($t1)", 0, 60, t0);
TESTINSN5LOAD("lwl $t0, 64($t1)", 0, 64, t0);
TESTINSN5LOAD("lwl $t0, 2($t1)", 0, 2, t0);
TESTINSN5LOAD("lwl $t0, 6($t1)", 0, 6, t0);
TESTINSN5LOAD("lwl $t0, 10($t1)", 0, 10, t0);
TESTINSN5LOAD("lwl $t0, 14($t1)", 0, 14, t0);
TESTINSN5LOAD("lwl $t0, 18($t1)", 0, 18, t0);
TESTINSN5LOAD("lwl $t0, 22($t1)", 0, 22, t0);
TESTINSN5LOAD("lwl $t0, 26($t1)", 0, 26, t0);
TESTINSN5LOAD("lwl $t0, 30($t1)", 0, 30, t0);
TESTINSN5LOAD("lwl $t0, 34($t1)", 0, 34, t0);
TESTINSN5LOAD("lwl $t0, 38($t1)", 0, 38, t0);
printf("LWR\n");
TESTINSN5LOAD("lwr $t0, 0($t1)", 0, 0, t0);
TESTINSN5LOAD("lwr $t0, 4($t1)", 0, 4, t0);
TESTINSN5LOAD("lwr $t0, 8($t1)", 0, 8, t0);
TESTINSN5LOAD("lwr $t0, 12($t1)", 0, 12, t0);
TESTINSN5LOAD("lwr $t0, 16($t1)", 0, 16, t0);
TESTINSN5LOAD("lwr $t0, 20($t1)", 0, 20, t0);
TESTINSN5LOAD("lwr $t0, 24($t1)", 0, 24, t0);
TESTINSN5LOAD("lwr $t0, 28($t1)", 0, 28, t0);
TESTINSN5LOAD("lwr $t0, 32($t1)", 0, 32, t0);
TESTINSN5LOAD("lwr $t0, 36($t1)", 0, 36, t0);
TESTINSN5LOAD("lwr $t0, 40($t1)", 0, 40, t0);
TESTINSN5LOAD("lwr $t0, 44($t1)", 0, 44, t0);
TESTINSN5LOAD("lwr $t0, 48($t1)", 0, 48, t0);
TESTINSN5LOAD("lwr $t0, 52($t1)", 0, 52, t0);
TESTINSN5LOAD("lwr $t0, 56($t1)", 0, 56, t0);
TESTINSN5LOAD("lwr $t0, 60($t1)", 0, 60, t0);
TESTINSN5LOAD("lwr $t0, 64($t1)", 0, 64, t0);
TESTINSN5LOAD("lwr $t0, 2($t1)", 0, 2, t0);
TESTINSN5LOAD("lwr $t0, 6($t1)", 0, 6, t0);
TESTINSN5LOAD("lwr $t0, 10($t1)", 0, 10, t0);
TESTINSN5LOAD("lwr $t0, 14($t1)", 0, 14, t0);
TESTINSN5LOAD("lwr $t0, 18($t1)", 0, 18, t0);
TESTINSN5LOAD("lwr $t0, 22($t1)", 0, 22, t0);
TESTINSN5LOAD("lwr $t0, 26($t1)", 0, 26, t0);
TESTINSN5LOAD("lwr $t0, 30($t1)", 0, 30, t0);
TESTINSN5LOAD("lwr $t0, 34($t1)", 0, 34, t0);
TESTINSN5LOAD("lwr $t0, 38($t1)", 0, 38, t0);
printf("MADD\n");
TESTINST3a("madd $t0, $t1", 0x6, 0x2, t0, t1);
TESTINST3a("madd $t0, $t1", 0x55, 0x28, t0, t1);
TESTINST3a("madd $t0, $t1", 0x18, 0xfff, t0, t1);
TESTINST3a("madd $t0, $t1", 0x7fffffff, 0x7fffffff, t0, t1);
TESTINST3a("madd $t0, $t1", 0xffffffff, 0x1, t0, t1);
TESTINST3a("madd $t0, $t1", 0x1, 0xffffffff, t0, t1);
TESTINST3a("madd $t0, $t1", 0x2, 0x6, t0, t1);
TESTINST3a("madd $t0, $t1", 0x356, 0x555, t0, t1);
printf("MADDU\n");
TESTINST3a("maddu $t0, $t1", 0x6, 0x2, t0, t1);
TESTINST3a("maddu $t0, $t1", 0x55, 0x28, t0, t1);
TESTINST3a("maddu $t0, $t1", 0x18, 0xfff, t0, t1);
TESTINST3a("maddu $t0, $t1", 0x7fffffff, 0x7fffffff, t0, t1);
TESTINST3a("maddu $t0, $t1", 0xffffffff, 0x1, t0, t1);
TESTINST3a("maddu $t0, $t1", 0x1, 0xffffffff, t0, t1);
TESTINST3a("maddu $t0, $t1", 0x2, 0x6, t0, t1);
TESTINST3a("maddu $t0, $t1", 0x356, 0x555, t0, t1);
printf("MOVN\n");
TESTINST1("movn $t0, $t1, $t2", 0x31415927, 0, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", 0x31415927, 1, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", 0x80000000, -1, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", 0x80000000, 1, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", 0x7fffffff, 1, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", 0x80000000, 0, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", 0x80000000, 1, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", 0x7fffffff, 0, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", 0x31415927, 0, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", 1, 0, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", 0, -1, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", 0, 0x80000000, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", 0x80000000, 1, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", 0x80000000, 0, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", 0x80000000, 1, t0, t1, t2);
TESTINST1("movn $t0, $t1, $t2", 0x7fffffff, 0, t0, t1, t2);
printf("MOVZ\n");
TESTINST1("movz $t0, $t1, $t2", 0x31415927, 0, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", 0x31415927, 1, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", 0x80000000, -1, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", 0x80000000, 1, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", 0x7fffffff, 1, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", 0x80000000, 0, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", 0x80000000, 1, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", 0x7fffffff, 0, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", 0x31415927, 0, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", 1, 0, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", 0, -1, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", 0, 0x80000000, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", 0x80000000, 1, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", 0x80000000, 0, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", 0x80000000, 1, t0, t1, t2);
TESTINST1("movz $t0, $t1, $t2", 0x7fffffff, 0, t0, t1, t2);
printf("MSUB\n");
TESTINST3a("msub $t0, $t1", 0x6, 0x2, t0, t1);
TESTINST3a("msub $t0, $t1", 0x55, 0x28, t0, t1);
TESTINST3a("msub $t0, $t1", 0x18, 0xfff, t0, t1);
TESTINST3a("msub $t0, $t1", 0x7fffffff, 0x7fffffff, t0, t1);
TESTINST3a("msub $t0, $t1", 0xffffffff, 0x1, t0, t1);
TESTINST3a("msub $t0, $t1", 0x1, 0xffffffff, t0, t1);
TESTINST3a("msub $t0, $t1", 0x2, 0x6, t0, t1);
TESTINST3a("msub $t0, $t1", 0x356, 0x555, t0, t1);
printf("MSUBU\n");
TESTINST3a("msubu $t0, $t1", 0x31415927, 0xffffffff, t0, t1);
TESTINST3a("msubu $t0, $t1", 0x31415927, 0xee00ee00, t0, t1);
TESTINST3a("msubu $t0, $t1", 0, 255, t0, t1);
TESTINST3a("msubu $t0, $t1", -1, 0, t0, t1);
TESTINST3a("msubu $t0, $t1", 0, 1, t0, t1);
TESTINST3a("msubu $t0, $t1", 0, 0, t0, t1);
TESTINST3a("msubu $t0, $t1", 0x80000000, -1, t0, t1);
TESTINST3a("msubu $t0, $t1", 0x80000000, 0x80000000, t0, t1);
TESTINST3a("msubu $t0, $t1", 0x7fffffff, 0, t0, t1);
TESTINST3a("msubu $t0, $t1", 0x80000000, 0x80000000, t0, t1);
TESTINST3a("msubu $t0, $t1", 0x7fffffff, 0x80000000, t0, t1);
TESTINST3a("msubu $t0, $t1", 0x80000000, 0xff000000, t0, t1);
TESTINST3a("msubu $t0, $t1", 0x7fffffff, 0x0dd00000, t0, t1);
TESTINST3a("msubu $t0, $t1", 0x31415927, 0xffffffff, t0, t1);
TESTINST3a("msubu $t0, $t1", 0x31415927, 0xee00ee00, t0, t1);
TESTINST3a("msubu $t0, $t1", 0, 255, t0, t1);
TESTINST3a("msubu $t0, $t1", 1, 0, t0, t1);
TESTINST3a("msubu $t0, $t1", 0, 1, t0, t1);
TESTINST3a("msubu $t0, $t1", -1, 0, t0, t1);
TESTINST3a("msubu $t0, $t1", 0, -1, t0, t1);
TESTINST3a("msubu $t0, $t1", 0, 0x80000000, t0, t1);
TESTINST3a("msubu $t0, $t1", 0x80000000, 0, t0, t1);
TESTINST3a("msubu $t0, $t1", 0x80000000, 0x80000000, t0, t1);
TESTINST3a("msubu $t0, $t1", 0x7fffffff, 0x80000000, t0, t1);
TESTINST3a("msubu $t0, $t1", 0x80000000, 0xff000000, t0, t1);
TESTINST3a("msubu $t0, $t1", 0x7fffffff, 0x0dd00000, t0, t1);
TESTINST3a("msubu $t0, $t1", 0xffffffff, 0, t0, t1);
TESTINST3a("msubu $t0, $t1", 0, 0xffffffff, t0, t1);
TESTINST3a("msubu $t0, $t1", 0xffffffff, 0xffffffff, t0, t1);
TESTINST3a("msubu $t0, $t1", 0x7fffffff, 0x7fffffff, t0, t1);
TESTINST3a("msubu $t0, $t1", 0x0000ffff, 0x0000ffff, t0, t1);
printf("MUL\n");
TESTINST1("mul $t0, $t1, $t2", 0x31415927, 0xffffffff, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0x80000000, -1, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0x7fffffff, 0, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0x80000000, 0xff000000, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0x7fffffff, 0x0dd00000, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0x31415927, 0xffffffff, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 1, 0, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0, -1, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0, 0x80000000, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0x80000000, 0, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0x80000000, 0xff000000, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0x7fffffff, 0x0dd00000, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0xffffffff, 0, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0, 0xffffffff, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0xffffffff, 0xffffffff, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0x7fffffff, 0x7fffffff, t0, t1, t2);
TESTINST1("mul $t0, $t1, $t2", 0x0000ffff, 0x0000ffff, t0, t1, t2);
printf("MULT\n");
TESTINST3a("mult $t0, $t1", 0x31415927, 0xffffffff, t0, t1);
TESTINST3a("mult $t0, $t1", 0x31415927, 0xee00ee00, t0, t1);
TESTINST3a("mult $t0, $t1", 0, 255, t0, t1);
TESTINST3a("mult $t0, $t1", -1, 0, t0, t1);
TESTINST3a("mult $t0, $t1", 0, 1, t0, t1);
TESTINST3a("mult $t0, $t1", 0, 0, t0, t1);
TESTINST3a("mult $t0, $t1", 0x80000000, -1, t0, t1);
TESTINST3a("mult $t0, $t1", 0x80000000, 0x80000000, t0, t1);
TESTINST3a("mult $t0, $t1", 0x7fffffff, 0, t0, t1);
TESTINST3a("mult $t0, $t1", 0x80000000, 0x80000000, t0, t1);
TESTINST3a("mult $t0, $t1", 0x7fffffff, 0x80000000, t0, t1);
TESTINST3a("mult $t0, $t1", 0x80000000, 0xff000000, t0, t1);
TESTINST3a("mult $t0, $t1", 0x7fffffff, 0x0dd00000, t0, t1);
TESTINST3a("mult $t0, $t1", 0x31415927, 0xffffffff, t0, t1);
TESTINST3a("mult $t0, $t1", 0x31415927, 0xee00ee00, t0, t1);
TESTINST3a("mult $t0, $t1", 0, 255, t0, t1);
TESTINST3a("mult $t0, $t1", 1, 0, t0, t1);
TESTINST3a("mult $t0, $t1", 0, 1, t0, t1);
TESTINST3a("mult $t0, $t1", -1, 0, t0, t1);
TESTINST3a("mult $t0, $t1", 0, -1, t0, t1);
TESTINST3a("mult $t0, $t1", 0, 0x80000000, t0, t1);
TESTINST3a("mult $t0, $t1", 0x80000000, 0, t0, t1);
TESTINST3a("mult $t0, $t1", 0x80000000, 0x80000000, t0, t1);
TESTINST3a("mult $t0, $t1", 0x7fffffff, 0x80000000, t0, t1);
TESTINST3a("mult $t0, $t1", 0x80000000, 0xff000000, t0, t1);
TESTINST3a("mult $t0, $t1", 0x7fffffff, 0x0dd00000, t0, t1);
TESTINST3a("mult $t0, $t1", 0xffffffff, 0, t0, t1);
TESTINST3a("mult $t0, $t1", 0, 0xffffffff, t0, t1);
TESTINST3a("mult $t0, $t1", 0xffffffff, 0xffffffff, t0, t1);
TESTINST3a("mult $t0, $t1", 0x7fffffff, 0x7fffffff, t0, t1);
TESTINST3a("mult $t0, $t1", 0x0000ffff, 0x0000ffff, t0, t1);
printf("MULTU\n");
TESTINST3a("multu $t0, $t1", 0x31415927, 0xffffffff, t0, t1);
TESTINST3a("multu $t0, $t1", 0x31415927, 0xee00ee00, t0, t1);
TESTINST3a("multu $t0, $t1", 0, 255, t0, t1);
TESTINST3a("multu $t0, $t1", -1, 0, t0, t1);
TESTINST3a("multu $t0, $t1", 0, 1, t0, t1);
TESTINST3a("multu $t0, $t1", 0, 0, t0, t1);
TESTINST3a("multu $t0, $t1", 0x80000000, -1, t0, t1);
TESTINST3a("multu $t0, $t1", 0x80000000, 0x80000000, t0, t1);
TESTINST3a("multu $t0, $t1", 0x7fffffff, 0, t0, t1);
TESTINST3a("multu $t0, $t1", 0x80000000, 0x80000000, t0, t1);
TESTINST3a("multu $t0, $t1", 0x7fffffff, 0x80000000, t0, t1);
TESTINST3a("multu $t0, $t1", 0x80000000, 0xff000000, t0, t1);
TESTINST3a("multu $t0, $t1", 0x7fffffff, 0x0dd00000, t0, t1);
TESTINST3a("multu $t0, $t1", 0x31415927, 0xffffffff, t0, t1);
TESTINST3a("multu $t0, $t1", 0x31415927, 0xee00ee00, t0, t1);
TESTINST3a("multu $t0, $t1", 0, 255, t0, t1);
TESTINST3a("multu $t0, $t1", 1, 0, t0, t1);
TESTINST3a("multu $t0, $t1", 0, 1, t0, t1);
TESTINST3a("multu $t0, $t1", -1, 0, t0, t1);
TESTINST3a("multu $t0, $t1", 0, -1, t0, t1);
TESTINST3a("multu $t0, $t1", 0, 0x80000000, t0, t1);
TESTINST3a("multu $t0, $t1", 0x80000000, 0, t0, t1);
TESTINST3a("multu $t0, $t1", 0x80000000, 0x80000000, t0, t1);
TESTINST3a("multu $t0, $t1", 0x7fffffff, 0x80000000, t0, t1);
TESTINST3a("multu $t0, $t1", 0x80000000, 0xff000000, t0, t1);
TESTINST3a("multu $t0, $t1", 0x7fffffff, 0x0dd00000, t0, t1);
TESTINST3a("multu $t0, $t1", 0xffffffff, 0, t0, t1);
TESTINST3a("multu $t0, $t1", 0, 0xffffffff, t0, t1);
TESTINST3a("multu $t0, $t1", 0xffffffff, 0xffffffff, t0, t1);
TESTINST3a("multu $t0, $t1", 0x7fffffff, 0x7fffffff, t0, t1);
TESTINST3a("multu $t0, $t1", 0x0000ffff, 0x0000ffff, t0, t1);
printf("NOR\n");
TESTINST1("nor $t0, $t1, $t2", 0x31415927, 0xffffffff, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0x80000000, -1, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0x7fffffff, 0, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0x80000000, 0xff000000, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0x7fffffff, 0x0dd00000, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0x31415927, 0xffffffff, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 1, 0, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0, -1, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0, 0x80000000, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0x80000000, 0, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0x80000000, 0xff000000, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0x7fffffff, 0x0dd00000, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0xffffffff, 0, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0, 0xffffffff, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0xffffffff, 0xffffffff, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0x7fffffff, 0x7fffffff, t0, t1, t2);
TESTINST1("nor $t0, $t1, $t2", 0x0000ffff, 0x0000ffff, t0, t1, t2);
#if (__mips==32) && (__mips_isa_rev>=2)
printf("WSBH\n");
TESTINST3("wsbh $t0, $t1", 0x2, t0, t1);
TESTINST3("wsbh $t0, $t1", 0x28, t0, t1);
TESTINST3("wsbh $t0, $t1", -258, t0, t1);
TESTINST3("wsbh $t0, $t1", 0x7fffffff, t0, t1);
TESTINST3("wsbh $t0, $t1", -11, t0, t1);
TESTINST3("wsbh $t0, $t1", 0xffffffff, t0, t1);
TESTINST3("wsbh $t0, $t1", 0x16, t0, t1);
TESTINST3("wsbh $t0, $t1", -1, t0, t1);
#endif
printf("NOT\n");
TESTINST3("not $t0, $t1", 0x2, t0, t1);
TESTINST3("not $t0, $t1", 0x28, t0, t1);
TESTINST3("not $t0, $t1", -258, t0, t1);
TESTINST3("not $t0, $t1", 0x7fffffff, t0, t1);
TESTINST3("not $t0, $t1", -11, t0, t1);
TESTINST3("not $t0, $t1", 0xffffffff, t0, t1);
TESTINST3("not $t0, $t1", 0x16, t0, t1);
TESTINST3("not $t0, $t1", -1, t0, t1);
printf("NEGU\n");
TESTINST3("negu $t0, $t1", 0x2, t0, t1);
TESTINST3("negu $t0, $t1", 0x28, t0, t1);
TESTINST3("negu $t0, $t1", -258, t0, t1);
TESTINST3("negu $t0, $t1", 0x7fffffff, t0, t1);
TESTINST3("negu $t0, $t1", -11, t0, t1);
TESTINST3("negu $t0, $t1", 0xffffffff, t0, t1);
TESTINST3("negu $t0, $t1", 0x16, t0, t1);
TESTINST3("negu $t0, $t1", -1, t0, t1);
printf("OR\n");
TESTINST1("or $t0, $t1, $t2", 0x31415927, 0xffffffff, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0x80000000, -1, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0x7fffffff, 0, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0x80000000, 0xff000000, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0x7fffffff, 0x0dd00000, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0x31415927, 0xffffffff, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 1, 0, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0, -1, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0, 0x80000000, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0x80000000, 0, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0x80000000, 0xff000000, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0x7fffffff, 0x0dd00000, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0xffffffff, 0, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0, 0xffffffff, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0xffffffff, 0xffffffff, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0x7fffffff, 0x7fffffff, t0, t1, t2);
TESTINST1("or $t0, $t1, $t2", 0x0000ffff, 0x0000ffff, t0, t1, t2);
printf("ORI\n");
TESTINST2("ori $t0, $t1, 0xffff", 0x31415927, 0xffff, t0, t1);
TESTINST2("ori $t0, $t1, 0xee00", 0x31415927, 0xee00, t0, t1);
TESTINST2("ori $t0, $t1, 255", 0, 255, t0, t1);
TESTINST2("ori $t0, $t1, 0", -1, 0, t0, t1);
TESTINST2("ori $t0, $t1, 1", 0, 1, t0, t1);
TESTINST2("ori $t0, $t1, 0", 0, 0, t0, t1);
TESTINST2("ori $t0, $t1, 0x8000", 0x80000000, 0x8000, t0, t1);
TESTINST2("ori $t0, $t1, 0", 0x7fffffff, 0, t0, t1);
TESTINST2("ori $t0, $t1, 0x8000", 0x80000000, 0x8000, t0, t1);
TESTINST2("ori $t0, $t1, 0x8000", 0x7fffffff, 0x8000, t0, t1);
TESTINST2("ori $t0, $t1, 0xff00", 0x80000000, 0xff00, t0, t1);
TESTINST2("ori $t0, $t1, 0x0dd0", 0x7fffffff, 0x0dd0, t0, t1);
TESTINST2("ori $t0, $t1, 0xffff", 0x31415927, 0xffff, t0, t1);
TESTINST2("ori $t0, $t1, 0xee00", 0x31415927, 0xee00, t0, t1);
TESTINST2("ori $t0, $t1, 255", 0, 255, t0, t1);
TESTINST2("ori $t0, $t1, 0", 1, 0, t0, t1);
TESTINST2("ori $t0, $t1, 1", 0, 1, t0, t1);
TESTINST2("ori $t0, $t1, 0", -1, 0, t0, t1);
TESTINST2("ori $t0, $t1, 0x8000", 0, 0x8000, t0, t1);
TESTINST2("ori $t0, $t1, 0", 0x8000, 0, t0, t1);
TESTINST2("ori $t0, $t1, 0x8000", 0x80000000, 0x8000, t0, t1);
TESTINST2("ori $t0, $t1, 0x8000", 0x7fffffff, 0x8000, t0, t1);
TESTINST2("ori $t0, $t1, 0xff00", 0x80000000, 0xff00, t0, t1);
TESTINST2("ori $t0, $t1, 0x0dd0", 0x7fffffff, 0x0dd0, t0, t1);
TESTINST2("ori $t0, $t1, 0", 0xffff, 0, t0, t1);
TESTINST2("ori $t0, $t1, 0xffff", 0, 0xffff, t0, t1);
TESTINST2("ori $t0, $t1, 0xffff", 0xffffffff, 0xffff, t0, t1);
TESTINST2("ori $t0, $t1, 0x7fff", 0x7fffffff, 0x7fff, t0, t1);
TESTINST2("ori $t0, $t1, 0x0000", 0x0000ffff, 0x0000, t0, t1);
#if (__mips==32) && (__mips_isa_rev>=2)
printf("ROTR\n");
TESTINST2("rotr $t0, $t1, 0x00000000", 0x31415927, 0x00000000, t0, t1);
TESTINST2("rotr $t0, $t1, 0x00000001", 0x31415927, 0x00000001, t0, t1);
TESTINST2("rotr $t0, $t1, 0x00000002", 0x31415927, 0x00000002, t0, t1);
TESTINST2("rotr $t0, $t1, 0x0000000F", 0x31415927, 0x0000000F, t0, t1);
TESTINST2("rotr $t0, $t1, 0x00000010", 0x31415927, 0x00000010, t0, t1);
TESTINST2("rotr $t0, $t1, 0x0000001F", 0x31415927, 0x0000001F, t0, t1);
TESTINST2("rotr $t0, $t1, 0x00000020", 0x31415927, 0x00000020, t0, t1);
TESTINST2("rotr $t0, $t1, 0x00000021", 0x31415927, 0x00000021, t0, t1);
TESTINST2("rotr $t0, $t1, 0x00000000", 0x00088000, 0x00000000, t0, t1);
TESTINST2("rotr $t0, $t1, 0x00000001", 0x00088000, 0x00000001, t0, t1);
TESTINST2("rotr $t0, $t1, 31", 0x00088000, 31, t0, t1);
TESTINST2("rotr $t0, $t1, 16", 0x00010000, 16, t0, t1);
TESTINST2("rotr $t0, $t1, 17", 0x00010000, 17, t0, t1);
TESTINST2("rotr $t0, $t1, 18", 0x00010000, 18, t0, t1);
TESTINST2("rotr $t0, $t1, 0", 0, 0, t0, t1);
TESTINST2("rotr $t0, $t1, 0xffff", 0xffff, 0xffff, t0, t1);
#endif
#if (__mips==32) && (__mips_isa_rev>=2)
printf("ROTRV\n");
TESTINST1("rotrv $t0, $t1, $t2", 0x31415927, 0xffffffff, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x80000000, -1, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x7fffffff, 0, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x80000000, 0xff000000, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x7fffffff, 0x0dd00000, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x31415927, 0xffffffff, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 1, 0, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0, -1, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0, 0x80000000, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x80000000, 0, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x80000000, 0xff000000, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x7fffffff, 0x0dd00000, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0xffffffff, 0, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0, 0xffffffff, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0xffffffff, 0xffffffff, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x7fffffff, 0x7fffffff, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x0000ffff, 0x0000ffff, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x31415927, 0x00000000, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x31415927, 0x00000001, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x31415927, 0x00000002, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x31415927, 0x0000000F, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x31415927, 0x00000010, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x31415927, 0x0000001F, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x31415927, 0x00000020, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x31415927, 0x00000021, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x00088000, 0x00000000, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x00088000, 0x00000001, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x00088000, 31, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x00010000, 16, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x00010000, 17, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0x00010000, 18, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("rotrv $t0, $t1, $t2", 0xffff, 0xffff, t0, t1, t2);
printf("SEB\n");
TESTINST3("seb $t0, $t1", 0x2, t0, t1);
TESTINST3("seb $t0, $t1", 0x28, t0, t1);
TESTINST3("seb $t0, $t1", -258, t0, t1);
TESTINST3("seb $t0, $t1", 0x7fffffff, t0, t1);
TESTINST3("seb $t0, $t1", -11, t0, t1);
TESTINST3("seb $t0, $t1", 0xffffffff, t0, t1);
TESTINST3("seb $t0, $t1", 0x16, t0, t1);
TESTINST3("seb $t0, $t1", -1, t0, t1);
printf("SEH\n");
TESTINST3("seh $t0, $t1", 0x2, t0, t1);
TESTINST3("seh $t0, $t1", 0x28, t0, t1);
TESTINST3("seh $t0, $t1", -258, t0, t1);
TESTINST3("seh $t0, $t1", 0x7fffffff, t0, t1);
TESTINST3("seh $t0, $t1", -11, t0, t1);
TESTINST3("seh $t0, $t1", 0xffffffff, t0, t1);
TESTINST3("seh $t0, $t1", 0x16, t0, t1);
TESTINST3("seh $t0, $t1", -1, t0, t1);
#endif
printf("SLL\n");
TESTINST2("sll $t0, $t1, 0x00000000", 0x31415927, 0x00000000, t0, t1);
TESTINST2("sll $t0, $t1, 0x00000001", 0x31415927, 0x00000001, t0, t1);
TESTINST2("sll $t0, $t1, 0x00000002", 0x31415927, 0x00000002, t0, t1);
TESTINST2("sll $t0, $t1, 0x0000000F", 0x31415927, 0x0000000F, t0, t1);
TESTINST2("sll $t0, $t1, 0x00000010", 0x31415927, 0x00000010, t0, t1);
TESTINST2("sll $t0, $t1, 0x0000001F", 0x31415927, 0x0000001F, t0, t1);
TESTINST2("sll $t0, $t1, 0x00000009", 0x31415927, 0x00000009, t0, t1);
TESTINST2("sll $t0, $t1, 0x0000000A", 0x31415927, 0x0000000A, t0, t1);
TESTINST2("sll $t0, $t1, 0x00000000", 0x00088000, 0x00000000, t0, t1);
TESTINST2("sll $t0, $t1, 0x00000001", 0x00088000, 0x00000001, t0, t1);
TESTINST2("sll $t0, $t1, 31", 0x00088000, 31, t0, t1);
TESTINST2("sll $t0, $t1, 16", 0x00010000, 16, t0, t1);
TESTINST2("sll $t0, $t1, 17", 0x00010000, 17, t0, t1);
TESTINST2("sll $t0, $t1, 18", 0x00010000, 18, t0, t1);
TESTINST2("sll $t0, $t1, 0", 0, 0, t0, t1);
printf("SLLV\n");
TESTINST1("sllv $t0, $t1, $t2", 0x31415927, 0xffffffff, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x80000000, -1, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x7fffffff, 0, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x80000000, 0xff000000, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x7fffffff, 0x0dd00000, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x31415927, 0xffffffff, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 1, 0, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0, -1, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0, 0x80000000, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x80000000, 0, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x80000000, 0xff000000, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x7fffffff, 0x0dd00000, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0xffffffff, 0, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0, 0xffffffff, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0xffffffff, 0xffffffff, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x7fffffff, 0x7fffffff, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x0000ffff, 0x0000ffff, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x31415927, 0x00000000, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x31415927, 0x00000001, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x31415927, 0x00000002, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x31415927, 0x0000000F, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x31415927, 0x00000010, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x31415927, 0x0000001F, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x31415927, 0x00000020, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x31415927, 0x00000021, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x00088000, 0x00000000, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x00088000, 0x00000001, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x00088000, 31, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x00010000, 16, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x00010000, 17, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0x00010000, 18, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("sllv $t0, $t1, $t2", 0xffff, 0xffff, t0, t1, t2);
printf("SLT\n");
TESTINST1("slt $t0, $t1, $t2", 0x31415927, 0xffffffff, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x80000000, -1, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x7fffffff, 0, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x80000000, 0xff000000, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x7fffffff, 0x0dd00000, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x31415927, 0xffffffff, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 1, 0, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0, -1, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0, 0x80000000, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x80000000, 0, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x80000000, 0xff000000, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x7fffffff, 0x0dd00000, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0xffffffff, 0, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0, 0xffffffff, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0xffffffff, 0xffffffff, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x7fffffff, 0x7fffffff, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x0000ffff, 0x0000ffff, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0xffffffff, 0, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0, 0xffffffff, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0xffffffff, 0xffffffff, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x7fffffff, 0x7fffffff, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x0000ffff, 0x0000ffff, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x31415927, 0x00000000, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x31415927, 0x00000001, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x31415927, 0x00000002, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x31415927, 0x0000000F, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x31415927, 0x00000010, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x31415927, 0x0000001F, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x31415927, 0x00000020, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x31415927, 0x00000021, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x00088000, 0x00000000, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x00088000, 0x00000001, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x00088000, 31, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x00010000, 16, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x00010000, 17, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0x00010000, 18, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("slt $t0, $t1, $t2", 0xffff, 0xffff, t0, t1, t2);
printf("SLTI\n");
TESTINST2("slti $t0, $t1, 0x00000000", 0x00000001, 0x31415927, t0, t1);
TESTINST2("slti $t0, $t1, 0x00000001", 0x31415927, 0x00000001, t0, t1);
TESTINST2("slti $t0, $t1, 0x00000002", 0x31415927, 0x00000002, t0, t1);
TESTINST2("slti $t0, $t1, 0x0000000F", 0x31415927, 0x0000000F, t0, t1);
TESTINST2("slti $t0, $t1, 0x00000010", 0x00000010, 0x00000010, t0, t1);
TESTINST2("slti $t0, $t1, 0x0000001F", 0x00000010, 0x31415927, t0, t1);
TESTINST2("slti $t0, $t1, 0x00000009", 0x31415927, 0x00000009, t0, t1);
TESTINST2("slti $t0, $t1, 0x0000000A", 0x31415927, 0x0000000A, t0, t1);
TESTINST2("slti $t0, $t1, 0x00000000", 0x00088000, 0x0000000A, t0, t1);
TESTINST2("slti $t0, $t1, 0x00000001", 0x00000000, 0x00000001, t0, t1);
TESTINST2("slti $t0, $t1, 31", 0x00088000, 31, t0, t1);
TESTINST2("slti $t0, $t1, 16", 0x00010000, 16, t0, t1);
TESTINST2("slti $t0, $t1, 17", 0x00010000, 17, t0, t1);
TESTINST2("slti $t0, $t1, 18", 0x00010000, 18, t0, t1);
TESTINST2("slti $t0, $t1, 0", 0, 0, t0, t1);
printf("SLTIU\n");
TESTINST2("sltiu $t0, $t1, 0x00000000", 0x00000001, 0x31415927, t0, t1);
TESTINST2("sltiu $t0, $t1, 0x00000001", 0x31415927, 0x00000001, t0, t1);
TESTINST2("sltiu $t0, $t1, 0x00000002", 0x31415927, 0x00000002, t0, t1);
TESTINST2("sltiu $t0, $t1, 0x0000000F", 0x31415927, 0x0000000F, t0, t1);
TESTINST2("sltiu $t0, $t1, 0x00000010", 0x00000010, 0x00000010, t0, t1);
TESTINST2("sltiu $t0, $t1, 0x0000001F", 0x00000010, 0x31415927, t0, t1);
TESTINST2("sltiu $t0, $t1, 0x00000009", 0x31415927, 0x00000009, t0, t1);
TESTINST2("sltiu $t0, $t1, 0x0000000A", 0x31415927, 0x0000000A, t0, t1);
TESTINST2("sltiu $t0, $t1, 0x00000000", 0x00088000, 0x0000000A, t0, t1);
TESTINST2("sltiu $t0, $t1, 0x00000001", 0x00000000, 0x00000001, t0, t1);
TESTINST2("sltiu $t0, $t1, 31", 0x00088000, 31, t0, t1);
TESTINST2("sltiu $t0, $t1, 16", 0x00010000, 16, t0, t1);
TESTINST2("sltiu $t0, $t1, 17", 0x00010000, 17, t0, t1);
TESTINST2("sltiu $t0, $t1, 18", 0x00010000, 18, t0, t1);
TESTINST2("sltiu $t0, $t1, 0", 0, 0, t0, t1);
printf("SLTU\n");
TESTINST1("sltu $t0, $t1, $t2", 0x31415927, 0xffffffff, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x80000000, -1, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x7fffffff, 0, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x80000000, 0xff000000, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x7fffffff, 0x0dd00000, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x31415927, 0xffffffff, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 1, 0, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0, -1, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0, 0x80000000, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x80000000, 0, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x80000000, 0xff000000, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x7fffffff, 0x0dd00000, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0xffffffff, 0, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0, 0xffffffff, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0xffffffff, 0xffffffff, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x7fffffff, 0x7fffffff, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x0000ffff, 0x0000ffff, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0xffffffff, 0, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0, 0xffffffff, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0xffffffff, 0xffffffff, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x7fffffff, 0x7fffffff, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x0000ffff, 0x0000ffff, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x31415927, 0x00000000, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x31415927, 0x00000001, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x31415927, 0x00000002, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x31415927, 0x0000000F, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x31415927, 0x00000010, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x31415927, 0x0000001F, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x31415927, 0x00000020, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x31415927, 0x00000021, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x00088000, 0x00000000, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x00088000, 0x00000001, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x00088000, 31, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x00010000, 16, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x00010000, 17, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0x00010000, 18, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("sltu $t0, $t1, $t2", 0xffff, 0xffff, t0, t1, t2);
printf("SRA\n");
TESTINST2("sra $t0, $t1, 0x00000000", 0x00000001, 0x31415927, t0, t1);
TESTINST2("sra $t0, $t1, 0x00000001", 0x31415927, 0x00000001, t0, t1);
TESTINST2("sra $t0, $t1, 0x00000002", 0x31415927, 0x00000002, t0, t1);
TESTINST2("sra $t0, $t1, 0x0000000F", 0x31415927, 0x0000000F, t0, t1);
TESTINST2("sra $t0, $t1, 0x00000010", 0x00000010, 0x00000010, t0, t1);
TESTINST2("sra $t0, $t1, 0x0000001F", 0x00000010, 0x31415927, t0, t1);
TESTINST2("sra $t0, $t1, 0x00000009", 0x31415927, 0x00000009, t0, t1);
TESTINST2("sra $t0, $t1, 0x0000000A", 0x31415927, 0x0000000A, t0, t1);
TESTINST2("sra $t0, $t1, 0x00000000", 0x00088000, 0x0000000A, t0, t1);
TESTINST2("sra $t0, $t1, 0x00000001", 0x00000000, 0x00000001, t0, t1);
TESTINST2("sra $t0, $t1, 31", 0x00088000, 31, t0, t1);
TESTINST2("sra $t0, $t1, 16", 0x00010000, 16, t0, t1);
TESTINST2("sra $t0, $t1, 17", 0x00010000, 17, t0, t1);
TESTINST2("sra $t0, $t1, 18", 0x00010000, 18, t0, t1);
TESTINST2("sra $t0, $t1, 0", 0, 0, t0, t1);
printf("SRAV\n");
TESTINST1("srav $t0, $t1, $t2", 0x31415927, 0xffffffff, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x80000000, -1, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x7fffffff, 0, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x80000000, 0xff000000, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x7fffffff, 0x0dd00000, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x31415927, 0xffffffff, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 1, 0, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0, -1, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0, 0x80000000, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x80000000, 0, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x80000000, 0xff000000, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x7fffffff, 0x0dd00000, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0xffffffff, 0, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0, 0xffffffff, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0xffffffff, 0xffffffff, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x7fffffff, 0x7fffffff, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x0000ffff, 0x0000ffff, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0xffffffff, 0, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0, 0xffffffff, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0xffffffff, 0xffffffff, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x7fffffff, 0x7fffffff, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x0000ffff, 0x0000ffff, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x31415927, 0x00000000, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x31415927, 0x00000001, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x31415927, 0x00000002, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x31415927, 0x0000000F, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x31415927, 0x00000010, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x31415927, 0x0000001F, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x31415927, 0x00000020, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x31415927, 0x00000021, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x00088000, 0x00000000, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x00088000, 0x00000001, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x00088000, 31, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x00010000, 16, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x00010000, 17, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0x00010000, 18, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("srav $t0, $t1, $t2", 0xffff, 0xffff, t0, t1, t2);
printf("SRL\n");
TESTINST2("srl $t0, $t1, 0x00000000", 0x00000001, 0x31415927, t0, t1);
TESTINST2("srl $t0, $t1, 0x00000001", 0x31415927, 0x00000001, t0, t1);
TESTINST2("srl $t0, $t1, 0x00000002", 0x31415927, 0x00000002, t0, t1);
TESTINST2("srl $t0, $t1, 0x0000000F", 0x31415927, 0x0000000F, t0, t1);
TESTINST2("srl $t0, $t1, 0x00000010", 0x00000010, 0x00000010, t0, t1);
TESTINST2("srl $t0, $t1, 0x0000001F", 0x00000010, 0x31415927, t0, t1);
TESTINST2("srl $t0, $t1, 0x00000009", 0x31415927, 0x00000009, t0, t1);
TESTINST2("srl $t0, $t1, 0x0000000A", 0x31415927, 0x0000000A, t0, t1);
TESTINST2("srl $t0, $t1, 0x00000000", 0x00088000, 0x0000000A, t0, t1);
TESTINST2("srl $t0, $t1, 0x00000001", 0x00000000, 0x00000001, t0, t1);
TESTINST2("srl $t0, $t1, 31", 0x00088000, 31, t0, t1);
TESTINST2("srl $t0, $t1, 16", 0x00010000, 16, t0, t1);
TESTINST2("srl $t0, $t1, 17", 0x00010000, 17, t0, t1);
TESTINST2("srl $t0, $t1, 18", 0x00010000, 18, t0, t1);
TESTINST2("srl $t0, $t1, 0", 0, 0, t0, t1);
printf("SRLV\n");
TESTINST1("srlv $t0, $t1, $t2", 0x31415927, 0xffffffff, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x80000000, -1, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x7fffffff, 0, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x80000000, 0xff000000, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x7fffffff, 0x0dd00000, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x31415927, 0xffffffff, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 1, 0, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0, -1, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0, 0x80000000, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x80000000, 0, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x80000000, 0xff000000, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x7fffffff, 0x0dd00000, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0xffffffff, 0, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0, 0xffffffff, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0xffffffff, 0xffffffff, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x7fffffff, 0x7fffffff, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x0000ffff, 0x0000ffff, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0xffffffff, 0, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0, 0xffffffff, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0xffffffff, 0xffffffff, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x7fffffff, 0x7fffffff, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x0000ffff, 0x0000ffff, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x31415927, 0x00000000, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x31415927, 0x00000001, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x31415927, 0x00000002, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x31415927, 0x0000000F, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x31415927, 0x00000010, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x31415927, 0x0000001F, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x31415927, 0x00000020, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x31415927, 0x00000021, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x00088000, 0x00000000, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x00088000, 0x00000001, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x00088000, 31, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x00010000, 16, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x00010000, 17, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0x00010000, 18, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("srlv $t0, $t1, $t2", 0xffff, 0xffff, t0, t1, t2);
printf("SUBU\n");
TESTINST1("subu $t0, $t1, $t2", 0x31415927, 0x00000001, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x31415927, 0x00001110, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x80000000, -1, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x7fffffff, 0, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x80000000, 0xff000000, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x7fffffff, 0x0dd00000, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x31415927, 0xffffffff, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 1, 0, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0, -1, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0, 0x80000000, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x80000000, 0, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x80000000, 0xff000000, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x7fffffff, 0x0dd00000, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0xffffffff, 0, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0, 0xffffffff, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0xffffffff, 0xffffffff, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x7fffffff, 0x7fffffff, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x0000ffff, 0x0000ffff, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0xffffffff, 0, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0, 0xffffffff, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0xffffffff, 0xffffffff, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x7fffffff, 0x7fffffff, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x0000ffff, 0x0000ffff, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x31415927, 0x00000000, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x31415927, 0x00000001, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x31415927, 0x00000002, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x31415927, 0x0000000F, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x31415927, 0x00000010, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x31415927, 0x0000001F, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x31415927, 0x00000020, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x31415927, 0x00000021, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x00088000, 0x00000000, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x00088000, 0x00000001, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x00088000, 31, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x00010000, 16, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x00010000, 17, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x00010000, 18, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0xffff, 0xffff, t0, t1, t2);
printf("SUB\n");
TESTINST1("subu $t0, $t1, $t2", 0x31415927, 0xffffffff, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x31415927, 0x27181728, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x31415927, 0x97181728, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 1, 0, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0, -1, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0, 0x80000000, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x80000000, 0, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x80000000, 0x7fffffff, t0, t1, t2);
TESTINST1("subu $t0, $t1, $t2", 0x7fffffff, 0x7fffffff, t0, t1, t2);
printf("XOR\n");
TESTINST1("xor $t0, $t1, $t2", 0x31415927, 0xffffffff, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0, 0, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0x80000000, -1, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0x7fffffff, 0, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0x80000000, 0xff000000, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0x7fffffff, 0x0dd00000, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0x31415927, 0xffffffff, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0x31415927, 0xee00ee00, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0, 255, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 1, 0, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0, 1, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", -1, 0, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0, -1, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0, 0x80000000, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0x80000000, 0, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0x80000000, 0x80000000, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0x7fffffff, 0x80000000, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0x80000000, 0xff000000, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0x7fffffff, 0x0dd00000, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0xffffffff, 0, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0, 0xffffffff, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0xffffffff, 0xffffffff, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0x7fffffff, 0x7fffffff, t0, t1, t2);
TESTINST1("xor $t0, $t1, $t2", 0x0000ffff, 0x0000ffff, t0, t1, t2);
printf("XORI\n");
TESTINST2("xori $t0, $t1, 0xffff", 0x31415927, 0xffff, t0, t1);
TESTINST2("xori $t0, $t1, 0xee00", 0x31415927, 0xee00, t0, t1);
TESTINST2("xori $t0, $t1, 255", 0, 255, t0, t1);
TESTINST2("xori $t0, $t1, 0", -1, 0, t0, t1);
TESTINST2("xori $t0, $t1, 1", 0, 1, t0, t1);
TESTINST2("xori $t0, $t1, 0", 0, 0, t0, t1);
TESTINST2("xori $t0, $t1, 0x8000", 0x80000000, 0x8000, t0, t1);
TESTINST2("xori $t0, $t1, 0", 0x7fffffff, 0, t0, t1);
TESTINST2("xori $t0, $t1, 0x8000", 0x80000000, 0x8000, t0, t1);
TESTINST2("xori $t0, $t1, 0x8000", 0x7fffffff, 0x8000, t0, t1);
TESTINST2("xori $t0, $t1, 0xff00", 0x80000000, 0xff00, t0, t1);
TESTINST2("xori $t0, $t1, 0x0dd0", 0x7fffffff, 0x0dd0, t0, t1);
TESTINST2("xori $t0, $t1, 0xffff", 0x31415927, 0xffff, t0, t1);
TESTINST2("xori $t0, $t1, 0xee00", 0x31415927, 0xee00, t0, t1);
TESTINST2("xori $t0, $t1, 255", 0, 255, t0, t1);
TESTINST2("xori $t0, $t1, 0", 1, 0, t0, t1);
TESTINST2("xori $t0, $t1, 1", 0, 1, t0, t1);
TESTINST2("xori $t0, $t1, 0", -1, 0, t0, t1);
TESTINST2("xori $t0, $t1, 0x8000", 0, 0x8000, t0, t1);
TESTINST2("xori $t0, $t1, 0", 0x8000, 0, t0, t1);
TESTINST2("xori $t0, $t1, 0x8000", 0x80000000, 0x8000, t0, t1);
TESTINST2("xori $t0, $t1, 0x8000", 0x7fffffff, 0x8000, t0, t1);
TESTINST2("xori $t0, $t1, 0xff00", 0x80000000, 0xff00, t0, t1);
TESTINST2("xori $t0, $t1, 0x0dd0", 0x7fffffff, 0x0dd0, t0, t1);
TESTINST2("xori $t0, $t1, 0", 0xffff, 0, t0, t1);
TESTINST2("xori $t0, $t1, 0xffff", 0, 0xffff, t0, t1);
TESTINST2("xori $t0, $t1, 0xffff", 0xffffffff, 0xffff, t0, t1);
TESTINST2("xori $t0, $t1, 0x7fff", 0x7fffffff, 0x7fff, t0, t1);
TESTINST2("xori $t0, $t1, 0x0000", 0x0000ffff, 0x0000, t0, t1);
printf("MFHI MFLO\n");
TESTINSN_HILO(0x31415927);
TESTINSN_HILO(0);
TESTINSN_HILO(-1);
TESTINSN_HILO(0xffffffff);
TESTINSN_HILO(0x8000);
TESTINSN_HILO(0x80000000);
TESTINSN_HILO(0x0000ffff);
TESTINSN_HILO(0x7fff);
TESTINSN_HILO(0x0dd0);
TESTINSN_HILO(0xff00);
return 0;
}