#if defined(__mips_hard_float) #include #include const float fs_f[] = { 0, 456.2489562, 3, -1, 1384.6, -7.2945676, 1000000000, -5786.47, 1752, 0.0024575, 0.00000001, -248562.76, -45786.476, 456.2489562, 34.00046, 45786.476, 1752065, 107, -45667.24, -7.2945676, -347856.475, 356047.56, -1.0, 23.04 }; unsigned long long data[] = { 0x1234567887654321ull, 0x66785bd668466667ull, 0xBFF550ff07788000ull, 0x0004789236500000ull, 0x3FF0001256789600ull, 0x0012365478000000ull, 0x252a2e2b252a2e2bull, 0x26852147962d2d2aull, 0x1234567887654321ull, 0x66785bd668466667ull, 0x789651ff07788055ull, 0x00ff23f4f1f5f6f8ull, 0x3FF0001256789600ull, 0xaabbcdfeefcd1256ull, 0xa1b2b2a1a3a5a6aaull, 0x2569874123654786ull }; unsigned int mem[] = { 0x4095A266, 0x66666666, 0xBFF00000, 0x00000000, 0x3FF00000, 0x00000000, 0x252a2e2b, 0x262d2d2a, 0xFFFFFFFF, 0xFFFFFFFF, 0x41D26580, 0xB487E5C9, 0x42026580, 0xB750E388, 0x3E45798E, 0xE2308C3A, 0x3FBF9ADD, 0x3746F65F }; // mfc1 rt, fs #define TESTINSNMOVE(instruction, offset, FS, RT) \ { \ float out; \ int out1; \ __asm__ volatile( \ ".set push \n\t" \ ".set oddspreg \n\t" \ "move $t0, %2\n\t" \ "lwc1 $" #FS ", "#offset"($t0)\n\t" \ instruction "\n\t" \ "mov.s %0, $" #FS"\n\t" \ "move %1, $" #RT "\n\t" \ ".set pop \n\t" \ : "=f" (out), "=r" (out1) \ : "r" (mem) \ : "t0", "$"#FS, #RT, "memory" \ ); \ printf("%s :: fs %f, rt 0x%x\n", \ instruction, out, out1); \ } // mfhc1 rt, fs #define TESTINSNMOVEd(instruction, offset, FS, RT) \ { \ unsigned int out; \ __asm__ volatile( \ "move $t0, %1\n\t" \ "ldc1 $" #FS ", "#offset"($t0)\n\t" \ instruction "\n\t" \ "move %0, $" #RT "\n\t" \ : "=r" (out) \ : "r" (data) \ : "t0", "$"#FS, #RT, "memory" \ ); \ printf("%s :: rt 0x%x\n", \ instruction, out); \ } // mtc1 rt, fs #define TESTINSNMOVEt(instruction, offset, FS, RT) \ { \ float out; \ int out1; \ __asm__ volatile( \ ".set push \n\t" \ ".set oddspreg \n\t" \ "move $t0, %2\n\t" \ "lw $" #RT ", "#offset"($t0)\n\t" \ instruction "\n\t" \ "mov.s %0, $" #FS"\n\t" \ "move %1, $" #RT "\n\t" \ ".set pop \n\t" \ : "=f" (out), "=r" (out1) \ : "r" (mem) \ : "t0", "$"#FS, #RT, "memory" \ ); \ printf("%s :: fs %f, rt 0x%x\n", \ instruction, out, out1); \ } // mthc1 rt, fs #define TESTINSNMOVEtd(instruction, offset, offset2, FS, RT) \ { \ unsigned long long out = 0; \ __asm__ volatile ( \ "move $t0, %2 \n\t" \ "move $t1, %1 \n\t" \ "ldc1 $"#FS"," #offset2"($t0)" "\n\t" \ "lw $"#RT"," #offset"($t1) \n\t" \ instruction "\n\t" \ "move $"#RT", %0 \n\t" \ "sdc1 $"#FS ", 0($"#RT")" "\n\t" \ : : "r" (&out), "r" (mem), "r" (data) \ : "t0", "t1", "$"#FS, #RT, "memory" \ ); \ printf("%s :: out: %llx\n", instruction, out); \ } // mov.s fd, fs #define TESTINSNMOVE1s(instruction, offset, FD, FS) \ { \ float out; \ int out1; \ __asm__ volatile( \ ".set push \n\t" \ ".set oddspreg \n\t" \ "move $t0, %2\n\t" \ "lwc1 $" #FS ", "#offset"($t0)\n\t" \ instruction "\n\t" \ "mov.s %0, $" #FD"\n\t" \ "mfc1 %1, $" #FD"\n\t" \ ".set pop \n\t" \ : "=f" (out), "=r" (out1) \ : "r" (fs_f) \ : "t0", "$"#FS, "$"#FD, "memory" \ ); \ printf("%s :: fs %f, rt 0x%x\n", \ instruction, out, out1); \ } // mov.d fd, fs #define TESTINSNMOVE1d(instruction, offset, FD, FS) \ { \ double out; \ int out1; \ __asm__ volatile( \ "move $t0, %2\n\t" \ "ldc1 $" #FS ", "#offset"($t0)\n\t" \ instruction "\n\t" \ "mov.d %0, $" #FD"\n\t" \ "mfc1 %1, $" #FD"\n\t" \ : "=f" (out), "=r" (out1) \ : "r" (fs_f) \ : "t0", "$"#FS, "$"#FD, "memory" \ ); \ printf("%s ::fs %f, rt 0x%x\n", \ instruction, out, out1); \ } // movf rd, rs #define TESTINSNMOVE2(instruction, RDval, RSval, RD, RS, cc) \ { \ int out; \ __asm__ volatile( \ "li $t0, 1\n\t" \ "move $t1, %3\n\t" \ "mtc1 $t0, $f0\n\t" \ "mtc1 $t1, $f2\n\t" \ "c.eq.s $f0, $f2\n\t" \ "move $" #RS ", %1\n\t" \ "move $" #RD ", %2\n\t" \ instruction "\n\t" \ "move %0, $" #RD "\n\t" \ : "=r" (out) \ : "r" (RSval), "r" (RDval), "r" (cc) \ : "t0", "t1", #RD, #RS \ ); \ printf("%s :: out: 0x%x, RDval: 0x%x, RSval: 0x%x, cc: %d\n",\ instruction, out, RDval, RSval, cc); \ } // movf.s fd, fs #define TESTINSNMOVE2s(instruction, FD, FS, cc, offset) \ { \ float out; \ __asm__ volatile( \ "li $t0, 1\n\t" \ "move $t1, %1\n\t" \ "mtc1 $t0, $f0\n\t" \ "mtc1 $t1, $f2\n\t" \ "c.eq.s $f0, $f2\n\t" \ "move $t0, %2\n\t" \ "lwc1 $" #FD ", 4($t0)\n\t" \ "lwc1 $" #FS ", "#offset"($t0)\n\t" \ instruction "\n\t" \ "mov.s %0, $" #FD"\n\t" \ : "=f" (out) \ : "r" (cc), "r" (fs_f) \ : "t0", "t1", "$"#FD, "$"#FS, "memory" \ ); \ printf("%s :: out: %f, cc: %d\n", \ instruction, out, cc); \ } // movf.d fd, fs #define TESTINSNMOVE2d(instruction, FD, FS, cc, offset) \ { \ double out; \ uint64_t outl; \ __asm__ volatile( \ "li $t0, 1 \n\t" \ "move $t1, %1 \n\t" \ "mtc1 $t0, $f0 \n\t" \ "mtc1 $t1, $f2 \n\t" \ "move $t0, %2 \n\t" \ "ldc1 $f4, 8($t0) \n\t" \ "c.eq.s $f0, $f2\n\t" \ "ldc1 $" #FS ", "#offset"($t0)\n\t" \ instruction "\n\t" \ "mov.d %0, $" #FD"\n\t" \ "sdc1 $f4, 0(%3)" \ : "=&f" (out) \ : "r" (cc), "r" (mem), "r" (&outl) \ : "t0", "t1", "$f0", "$f2", "$f4", "$"#FS, "$"#FD, "memory" \ ); \ printf("%s :: out: 0x%x 0x%x, cc: %d\n", \ instruction, (uint32_t)outl, (uint32_t)(outl >> 32), cc); \ } // movn.s fd, fs, rt #define TESTINSNMOVEN1s(instruction, offset, RTval, FD, FS, RT) \ { \ float out; \ int out1; \ __asm__ volatile( \ "move $" #RT ", %3\n\t" \ "move $t0, %2\n\t" \ "lwc1 $" #FS ", "#offset"($t0)\n\t" \ "mtc1 $0, $" #FD "\n\t" \ instruction "\n\t" \ "mov.s %0, $" #FD"\n\t" \ "mfc1 %1, $" #FD"\n\t" \ : "=f" (out), "=r" (out1) \ : "r" (fs_f), "r" (RTval) \ : "t0", "$"#FS, "$"#FD, #RT, "memory" \ ); \ printf("%s :: fs rt 0x%x\n", \ instruction, out1); \ } // movn.d fd, fs, rt #define TESTINSNMOVEN1d(instruction, offset, RTval, FD, FS, RT) \ { \ double out; \ int out1; \ __asm__ volatile( \ "move $" #RT ", %3\n\t" \ "move $t0, %2\n\t" \ "ldc1 $" #FS ", "#offset"($t0)\n\t" \ "mtc1 $0, $" #FD "\n\t" \ "mtc1 $0, $" #FD + 1"\n\t" \ instruction "\n\t" \ "mov.d %0, $" #FD"\n\t" \ "mfc1 %1, $" #FD"\n\t" \ : "=f" (out), "=r" (out1) \ : "r" (fs_f), "r" (RTval) \ : "t0", "$"#FS, "$"#FD, #RT, "memory" \ ); \ printf("%s :: fs %lf, rt 0x%x\n", \ instruction, out, out1); \ } int main() { printf("MFC1\n"); TESTINSNMOVE("mfc1 $t1, $f0", 0, f0, t1); TESTINSNMOVE("mfc1 $t2, $f1", 4, f1, t2); TESTINSNMOVE("mfc1 $t3, $f2", 8, f2, t3); TESTINSNMOVE("mfc1 $t4, $f3", 12, f3, t4); TESTINSNMOVE("mfc1 $t5, $f4", 16, f4, t5); TESTINSNMOVE("mfc1 $t6, $f5", 20, f5, t6); TESTINSNMOVE("mfc1 $t7, $f6", 24, f6, t7); TESTINSNMOVE("mfc1 $v0, $f7", 28, f7, v0); TESTINSNMOVE("mfc1 $v1, $f8", 32, f8, v1); TESTINSNMOVE("mfc1 $s0, $f9", 36, f9, s0); TESTINSNMOVE("mfc1 $s1, $f10", 40, f10, s1); TESTINSNMOVE("mfc1 $s2, $f11", 44, f11, s2); TESTINSNMOVE("mfc1 $s3, $f12", 48, f12, s3); TESTINSNMOVE("mfc1 $s4, $f13", 52, f13, s4); TESTINSNMOVE("mfc1 $s5, $f14", 56, f14, s5); TESTINSNMOVE("mfc1 $s6, $f15", 60, f15, s6); TESTINSNMOVE("mfc1 $s7, $f16", 64, f16, s7); TESTINSNMOVE("mfc1 $a0, $f17", 0, f17, a0); TESTINSNMOVE("mfc1 $a1, $f18", 4, f18, a1); TESTINSNMOVE("mfc1 $a2, $f19", 8, f19, a2); TESTINSNMOVE("mfc1 $a3, $f20", 12, f20, a3); TESTINSNMOVE("mfc1 $v0, $f21", 16, f21, v0); TESTINSNMOVE("mfc1 $v1, $f22", 20, f22, v1); TESTINSNMOVE("mfc1 $t8, $f23", 24, f23, t8); TESTINSNMOVE("mfc1 $t9, $f24", 28, f24, t9); TESTINSNMOVE("mfc1 $t1, $f25", 32, f25, t1); TESTINSNMOVE("mfc1 $t2, $f26", 36, f26, t2); printf("MTC1\n"); TESTINSNMOVEt("mtc1 $t1, $f0", 0, f0, t1); TESTINSNMOVEt("mtc1 $t2, $f1", 4, f1, t2); TESTINSNMOVEt("mtc1 $t3, $f2", 8, f2, t3); TESTINSNMOVEt("mtc1 $t4, $f3", 12, f3, t4); TESTINSNMOVEt("mtc1 $t5, $f4", 16, f4, t5); TESTINSNMOVEt("mtc1 $t6, $f5", 20, f5, t6); TESTINSNMOVEt("mtc1 $t7, $f6", 24, f6, t7); TESTINSNMOVEt("mtc1 $v0, $f7", 28, f7, v0); TESTINSNMOVEt("mtc1 $v1, $f8", 32, f8, v1); TESTINSNMOVEt("mtc1 $s0, $f9", 36, f9, s0); TESTINSNMOVEt("mtc1 $s1, $f10", 40, f10, s1); TESTINSNMOVEt("mtc1 $s2, $f11", 44, f11, s2); TESTINSNMOVEt("mtc1 $s3, $f12", 48, f12, s3); TESTINSNMOVEt("mtc1 $s4, $f13", 52, f13, s4); TESTINSNMOVEt("mtc1 $s5, $f14", 56, f14, s5); TESTINSNMOVEt("mtc1 $s6, $f15", 60, f15, s6); TESTINSNMOVEt("mtc1 $s7, $f16", 64, f16, s7); TESTINSNMOVEt("mtc1 $a0, $f17", 2, f17, a0); TESTINSNMOVEt("mtc1 $a1, $f18", 6, f18, a1); TESTINSNMOVEt("mtc1 $a2, $f19", 10, f19, a2); TESTINSNMOVEt("mtc1 $a3, $f20", 14, f20, a3); TESTINSNMOVEt("mtc1 $v0, $f21", 18, f21, v0); TESTINSNMOVEt("mtc1 $v1, $f22", 22, f22, v1); TESTINSNMOVEt("mtc1 $t8, $f23", 26, f23, t8); TESTINSNMOVEt("mtc1 $t9, $f24", 30, f24, t9); TESTINSNMOVEt("mtc1 $t1, $f25", 34, f25, t1); TESTINSNMOVEt("mtc1 $t2, $f26", 38, f26, t2); #if defined(__mips__) && ((defined(__mips_isa_rev) && __mips_isa_rev >= 2)) printf("MFHC1\n"); TESTINSNMOVEd("mfhc1 $t1, $f0", 0, f0, t1); TESTINSNMOVEd("mfhc1 $t2, $f2", 8, f2, t2); TESTINSNMOVEd("mfhc1 $t3, $f4", 16, f4, t3); TESTINSNMOVEd("mfhc1 $v0, $f6", 24, f6, v0); TESTINSNMOVEd("mfhc1 $v1, $f8", 32, f8, v1); TESTINSNMOVEd("mfhc1 $a0, $f10", 40, f10, a0); TESTINSNMOVEd("mfhc1 $a1, $f12", 48, f12, a1); TESTINSNMOVEd("mfhc1 $a2, $f14", 56, f14, a2); TESTINSNMOVEd("mfhc1 $a3, $f16", 64, f16, a3); TESTINSNMOVEd("mfhc1 $s0, $f18", 72, f18, s0); TESTINSNMOVEd("mfhc1 $s1, $f20", 80, f20, s1); TESTINSNMOVEd("mfhc1 $s2, $f22", 88, f22, s2); TESTINSNMOVEd("mfhc1 $s3, $f24", 96, f24, s3); TESTINSNMOVEd("mfhc1 $s4, $f26", 104, f26, s4); TESTINSNMOVEd("mfhc1 $s5, $f28", 112, f28, s5); TESTINSNMOVEd("mfhc1 $s6, $f30", 120, f30, s6); printf("MTHC1\n"); TESTINSNMOVEtd("mthc1 $t2, $f0", 0, 0, f0, t2); TESTINSNMOVEtd("mthc1 $t3, $f2", 4, 8, f2, t3); TESTINSNMOVEtd("mthc1 $v0, $f4", 8, 16, f4, v0); TESTINSNMOVEtd("mthc1 $v1, $f6", 12, 24, f6, v1); TESTINSNMOVEtd("mthc1 $a0, $f8", 16, 32, f8, a0); TESTINSNMOVEtd("mthc1 $a1, $f10", 20, 40, f10, a1); TESTINSNMOVEtd("mthc1 $a2, $f12", 24, 48, f12, a2); TESTINSNMOVEtd("mthc1 $a3, $f14", 28, 56, f14, a3); TESTINSNMOVEtd("mthc1 $s0, $f16", 32, 64, f16, s0); TESTINSNMOVEtd("mthc1 $s1, $f18", 36, 72, f18, s1); TESTINSNMOVEtd("mthc1 $s2, $f20", 40, 80, f20, s2); TESTINSNMOVEtd("mthc1 $s3, $f22", 44, 88, f22, s3); TESTINSNMOVEtd("mthc1 $s4, $f24", 48, 96, f24, s4); TESTINSNMOVEtd("mthc1 $s5, $f26", 52, 104, f26, s5); TESTINSNMOVEtd("mthc1 $s6, $f28", 56, 112, f28, s6); TESTINSNMOVEtd("mthc1 $s7, $f30", 60, 120, f30, s7); #endif printf("MOV.S\n"); TESTINSNMOVE1s("mov.s $f0, $f0", 0, f0, f0); TESTINSNMOVE1s("mov.s $f0, $f1", 4, f0, f1); TESTINSNMOVE1s("mov.s $f1, $f2", 8, f1, f2); TESTINSNMOVE1s("mov.s $f2, $f3", 12, f2, f3); TESTINSNMOVE1s("mov.s $f3, $f4", 16, f3, f4); TESTINSNMOVE1s("mov.s $f4, $f5", 20, f4, f5); TESTINSNMOVE1s("mov.s $f5, $f6", 24, f5, f6); TESTINSNMOVE1s("mov.s $f6, $f7", 28, f6, f7); TESTINSNMOVE1s("mov.s $f7, $f8", 32, f7, f8); TESTINSNMOVE1s("mov.s $f8, $f9", 36, f8, f9); TESTINSNMOVE1s("mov.s $f9, $f10", 40, f9, f10); TESTINSNMOVE1s("mov.s $f10, $f11", 44, f10, f11); TESTINSNMOVE1s("mov.s $f11, $f12", 48, f11, f12); TESTINSNMOVE1s("mov.s $f12, $f13", 52, f12, f13); TESTINSNMOVE1s("mov.s $f13, $f14", 56, f13, f14); TESTINSNMOVE1s("mov.s $f14, $f15", 60, f14, f15); TESTINSNMOVE1s("mov.s $f15, $f16", 64, f15, f16); TESTINSNMOVE1s("mov.s $f16, $f17", 0, f16, f17); TESTINSNMOVE1s("mov.s $f17, $f18", 4, f17, f18); TESTINSNMOVE1s("mov.s $f18, $f19", 8, f18, f19); TESTINSNMOVE1s("mov.s $f19, $f20", 12, f19, f20); TESTINSNMOVE1s("mov.s $f20, $f21", 16, f20, f21); TESTINSNMOVE1s("mov.s $f21, $f22", 20, f21, f22); TESTINSNMOVE1s("mov.s $f22, $f23", 24, f22, f23); TESTINSNMOVE1s("mov.s $f23, $f24", 28, f23, f24); TESTINSNMOVE1s("mov.s $f24, $f25", 32, f24, f25); TESTINSNMOVE1s("mov.s $f25, $f26", 36, f25, f26); printf("MOV.D\n"); TESTINSNMOVE1d("mov.d $f0, $f0", 0, f0, f0); TESTINSNMOVE1d("mov.d $f0, $f0", 8, f0, f0); TESTINSNMOVE1d("mov.d $f0, $f2", 16, f0, f2); TESTINSNMOVE1d("mov.d $f2, $f4", 24, f2, f4); TESTINSNMOVE1d("mov.d $f2, $f4", 32, f2, f4); TESTINSNMOVE1d("mov.d $f4, $f6", 40, f4, f6); TESTINSNMOVE1d("mov.d $f4, $f6", 48, f4, f6); TESTINSNMOVE1d("mov.d $f6, $f8", 56, f6, f8); TESTINSNMOVE1d("mov.d $f6, $f8", 64, f6, f8); TESTINSNMOVE1d("mov.d $f8, $f10", 0, f8, f10); TESTINSNMOVE1d("mov.d $f8, $f10", 8, f8, f10); TESTINSNMOVE1d("mov.d $f10, $f12", 16, f10, f12); TESTINSNMOVE1d("mov.d $f10, $f12", 24, f10, f12); TESTINSNMOVE1d("mov.d $f12, $f14", 32, f12, f14); TESTINSNMOVE1d("mov.d $f12, $f14", 40, f12, f14); TESTINSNMOVE1d("mov.d $f14, $f16", 48, f14, f16); TESTINSNMOVE1d("mov.d $f14, $f16", 56, f14, f16); TESTINSNMOVE1d("mov.d $f16, $f18", 64, f16, f18); TESTINSNMOVE1d("mov.d $f16, $f18", 0, f16, f18); TESTINSNMOVE1d("mov.d $f18, $f20", 8, f18, f20); TESTINSNMOVE1d("mov.d $f18, $f20", 16, f18, f20); TESTINSNMOVE1d("mov.d $f20, $f22", 24, f20, f22); TESTINSNMOVE1d("mov.d $f20, $f22", 32, f20, f22); TESTINSNMOVE1d("mov.d $f22, $f24", 40, f22, f24); TESTINSNMOVE1d("mov.d $f22, $f24", 48, f22, f24); TESTINSNMOVE1d("mov.d $f24, $f26", 56, f24, f26); TESTINSNMOVE1d("mov.d $f24, $f26", 64, f24, f26); printf("MOVF\n"); TESTINSNMOVE2("movf $t0, $t1, $fcc0", 0, 0xffffffff, t0, t1, 1); TESTINSNMOVE2("movf $t0, $t1, $fcc0", 0xffffffff, 0xffffffff, t0, t1, 0); TESTINSNMOVE2("movf $t0, $t1, $fcc0", 555, 0xffffffff, t0, t1, 1); TESTINSNMOVE2("movf $t0, $t1, $fcc0", 0, 5, t0, t1, 0); TESTINSNMOVE2("movf $t0, $t1, $fcc0", 0, -1, t0, t1, 1); TESTINSNMOVE2("movf $t0, $t1, $fcc0", 0xffffffff, 25, t0, t1, 0); TESTINSNMOVE2("movf $t0, $t1, $fcc0", 0xffffffff, 0, t0, t1, 1); TESTINSNMOVE2("movf $t0, $t1, $fcc0", 0xffffffff, 66, t0, t1, 0); TESTINSNMOVE2("movf $t0, $t1, $fcc4", 0, 0xffffffff, t0, t1, 1); TESTINSNMOVE2("movf $t0, $t1, $fcc4", 0xffffffff, 0xffffffff, t0, t1, 0); TESTINSNMOVE2("movf $t0, $t1, $fcc4", 555, 0xffffffff, t0, t1, 1); TESTINSNMOVE2("movf $t0, $t1, $fcc4", 0, 5, t0, t1, 0); TESTINSNMOVE2("movf $t0, $t1, $fcc4", 0, -1, t0, t1, 1); TESTINSNMOVE2("movf $t0, $t1, $fcc4", 0xffffffff, 25, t0, t1, 0); TESTINSNMOVE2("movf $t0, $t1, $fcc4", 0xffffffff, 0, t0, t1, 1); TESTINSNMOVE2("movf $t0, $t1, $fcc4", 0xffffffff, 66, t0, t1, 0); printf("MOVF.S\n"); TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 1, 0); TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 1, 4); TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 1, 8); TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 1, 12); TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 1, 16); TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 1, 20); TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 1, 24); TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 1, 28); TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 1, 32); TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 1, 36) TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 1, 40) TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 1, 44) TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 1, 48) TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 1, 52) TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 1, 56) TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 0, 0); TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 0, 4); TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 0, 8); TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 0, 12); TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 0, 16); TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 0, 20); TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 0, 24); TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 0, 28); TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 0, 32); TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 0, 36); TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 0, 40); TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 0, 44); TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 0, 48); TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 0, 52); TESTINSNMOVE2s("movf.s $f4, $f6, $fcc0", f4, f6, 0, 56); printf("MOVF.D\n"); TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 1, 0); TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 1, 8); TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 1, 16); TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 1, 24); TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 1, 32); TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 1, 40); TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 1, 48); TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 1, 56); TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 1, 64); TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 1, 0) TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 1, 8) TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 1, 16) TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 1, 24) TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 1, 32) TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 1, 40) TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 0, 48); TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 0, 56); TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 0, 64); TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 0, 0); TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 0, 8); TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 0, 16); TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 0, 24); TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 0, 32); TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 0, 40); TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 0, 48); TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 0, 56); TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 0, 64); TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 0, 0); TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 0, 8); TESTINSNMOVE2d("movf.d $f4, $f6, $fcc0", f4, f6, 0, 16); printf("MOVN.S\n"); TESTINSNMOVEN1s("movn.s $f0, $f2, $t3", 0, 0, f0, f2, t3); TESTINSNMOVEN1s("movn.s $f0, $f2, $t3", 4, 1, f0, f2, t3); TESTINSNMOVEN1s("movn.s $f0, $f2, $t3", 8, 0xffff, f0, f2, t3); TESTINSNMOVEN1s("movn.s $f0, $f2, $t3", 12, -1, f0, f2, t3); TESTINSNMOVEN1s("movn.s $f0, $f2, $t3", 16, 5, f0, f2, t3); TESTINSNMOVEN1s("movn.s $f0, $f2, $t3", 20, 0, f0, f2, t3); TESTINSNMOVEN1s("movn.s $f0, $f2, $t3", 24, 0, f0, f2, t3); TESTINSNMOVEN1s("movn.s $f0, $f2, $t3", 28, 5, f0, f2, t3); TESTINSNMOVEN1s("movn.s $f0, $f2, $t3", 32, 125487, f0, f2, t3); TESTINSNMOVEN1s("movn.s $f0, $f2, $t3", 36, 68, f0, f2, t3); TESTINSNMOVEN1s("movn.s $f0, $f2, $t3", 40, -122544, f0, f2, t3); TESTINSNMOVEN1s("movn.s $f0, $f2, $t3", 44, 0, f0, f2, t3); TESTINSNMOVEN1s("movn.s $f0, $f2, $t3", 48, 0, f0, f2, t3); TESTINSNMOVEN1s("movn.s $f0, $f2, $t3", 52, 0xffffffff, f0, f2, t3); TESTINSNMOVEN1s("movn.s $f0, $f2, $t3", 56, 0x80000000, f0, f2, t3); TESTINSNMOVEN1s("movn.s $f0, $f2, $t3", 60, 0x7fffffff, f0, f2, t3); printf("MOVN.D\n"); TESTINSNMOVEN1s("movn.d $f0, $f2, $t3", 0, 0, f0, f2, t3); TESTINSNMOVEN1s("movn.d $f0, $f2, $t3", 4, 1, f0, f2, t3); TESTINSNMOVEN1s("movn.d $f0, $f2, $t3", 8, 0xffff, f0, f2, t3); TESTINSNMOVEN1s("movn.d $f0, $f2, $t3", 12, -1, f0, f2, t3); TESTINSNMOVEN1s("movn.d $f0, $f2, $t3", 16, 5, f0, f2, t3); TESTINSNMOVEN1s("movn.d $f0, $f2, $t3", 20, 0, f0, f2, t3); TESTINSNMOVEN1s("movn.d $f0, $f2, $t3", 24, 0, f0, f2, t3); TESTINSNMOVEN1s("movn.d $f0, $f2, $t3", 28, 5, f0, f2, t3); TESTINSNMOVEN1s("movn.d $f0, $f2, $t3", 32, 125487, f0, f2, t3); TESTINSNMOVEN1s("movn.d $f0, $f2, $t3", 36, 68, f0, f2, t3); TESTINSNMOVEN1s("movn.d $f0, $f2, $t3", 40, -122544, f0, f2, t3); TESTINSNMOVEN1s("movn.d $f0, $f2, $t3", 44, 0, f0, f2, t3); TESTINSNMOVEN1s("movn.d $f0, $f2, $t3", 48, 0, f0, f2, t3); TESTINSNMOVEN1s("movn.d $f0, $f2, $t3", 52, 0xffffffff, f0, f2, t3); TESTINSNMOVEN1s("movn.d $f0, $f2, $t3", 56, 0x80000000, f0, f2, t3); TESTINSNMOVEN1s("movn.d $f0, $f2, $t3", 60, 0x7fffffff, f0, f2, t3); printf("MOVT\n"); TESTINSNMOVE2("movt $t0, $t1, $fcc0", 0, 0xffffffff, t0, t1, 1); TESTINSNMOVE2("movt $t0, $t1, $fcc0", 0xffffffff, 0xffffffff, t0, t1, 0); TESTINSNMOVE2("movt $t0, $t1, $fcc0", 555, 0xffffffff, t0, t1, 1); TESTINSNMOVE2("movt $t0, $t1, $fcc0", 0, 5, t0, t1, 0); TESTINSNMOVE2("movt $t0, $t1, $fcc0", 0, -1, t0, t1, 1); TESTINSNMOVE2("movt $t0, $t1, $fcc0", 0xffffffff, 25, t0, t1, 0); TESTINSNMOVE2("movt $t0, $t1, $fcc0", 0xffffffff, 0, t0, t1, 1); TESTINSNMOVE2("movt $t0, $t1, $fcc0", 0xffffffff, 66, t0, t1, 0); TESTINSNMOVE2("movt $t0, $t1, $fcc4", 0, 0xffffffff, t0, t1, 1); TESTINSNMOVE2("movt $t0, $t1, $fcc4", 0xffffffff, 0xffffffff, t0, t1, 0); TESTINSNMOVE2("movt $t0, $t1, $fcc4", 555, 0xffffffff, t0, t1, 1); TESTINSNMOVE2("movt $t0, $t1, $fcc4", 0, 5, t0, t1, 0); TESTINSNMOVE2("movt $t0, $t1, $fcc4", 0, -1, t0, t1, 1); TESTINSNMOVE2("movt $t0, $t1, $fcc4", 0xffffffff, 25, t0, t1, 0); TESTINSNMOVE2("movt $t0, $t1, $fcc4", 0xffffffff, 0, t0, t1, 1); TESTINSNMOVE2("movt $t0, $t1, $fcc4", 0xffffffff, 66, t0, t1, 0); printf("MOVT.S\n"); TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 1, 0); TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 1, 4); TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 1, 8); TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 1, 12); TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 1, 16); TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 1, 20); TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 1, 24); TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 1, 28); TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 1, 32); TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 1, 36) TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 1, 40) TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 1, 44) TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 1, 48) TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 1, 52) TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 1, 56) TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 0, 0); TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 0, 4); TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 0, 8); TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 0, 12); TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 0, 16); TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 0, 20); TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 0, 24); TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 0, 28); TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 0, 32); TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 0, 36); TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 0, 40); TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 0, 44); TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 0, 48); TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 0, 52); TESTINSNMOVE2s("movt.s $f4, $f6, $fcc0", f4, f6, 0, 56); printf("MOVT.D\n"); TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 1, 0); TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 1, 8); TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 1, 16); TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 1, 24); TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 1, 32); TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 1, 40); TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 1, 48); TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 1, 56); TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 1, 64); TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 1, 0) TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 1, 8) TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 1, 16) TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 1, 24) TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 1, 32) TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 1, 40) TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 0, 48); TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 0, 56); TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 0, 64); TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 0, 0); TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 0, 8); TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 0, 16); TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 0, 24); TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 0, 32); TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 0, 40); TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 0, 48); TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 0, 56); TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 0, 64); TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 0, 0); TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 0, 8); TESTINSNMOVE2d("movt.d $f4, $f6, $fcc0", f4, f6, 0, 16); printf("MOVZ.S\n"); TESTINSNMOVEN1s("movz.s $f0, $f2, $t3", 0, 0, f0, f2, t3); TESTINSNMOVEN1s("movz.s $f0, $f2, $t3", 4, 1, f0, f2, t3); TESTINSNMOVEN1s("movz.s $f0, $f2, $t3", 8, 0xffff, f0, f2, t3); TESTINSNMOVEN1s("movz.s $f0, $f2, $t3", 12, -1, f0, f2, t3); TESTINSNMOVEN1s("movz.s $f0, $f2, $t3", 16, 5, f0, f2, t3); TESTINSNMOVEN1s("movz.s $f0, $f2, $t3", 20, 0, f0, f2, t3); TESTINSNMOVEN1s("movz.s $f0, $f2, $t3", 24, 0, f0, f2, t3); TESTINSNMOVEN1s("movz.s $f0, $f2, $t3", 24, 0, f0, f2, t3); TESTINSNMOVEN1s("movz.s $f0, $f2, $t3", 28, 5, f0, f2, t3); TESTINSNMOVEN1s("movz.s $f0, $f2, $t3", 32, 125487, f0, f2, t3); TESTINSNMOVEN1s("movz.s $f0, $f2, $t3", 36, 68, f0, f2, t3); TESTINSNMOVEN1s("movz.s $f0, $f2, $t3", 40, -122544, f0, f2, t3); TESTINSNMOVEN1s("movz.s $f0, $f2, $t3", 44, 0, f0, f2, t3); TESTINSNMOVEN1s("movz.s $f0, $f2, $t3", 48, 0, f0, f2, t3); TESTINSNMOVEN1s("movz.s $f0, $f2, $t3", 52, 0xffffffff, f0, f2, t3); TESTINSNMOVEN1s("movz.s $f0, $f2, $t3", 56, 0x80000000, f0, f2, t3); TESTINSNMOVEN1s("movz.s $f0, $f2, $t3", 60, 0x7fffffff, f0, f2, t3); printf("MOVZ.D\n"); TESTINSNMOVEN1s("movz.d $f0, $f2, $t3", 0, 0, f0, f2, t3); TESTINSNMOVEN1s("movz.d $f0, $f2, $t3", 4, 1, f0, f2, t3); TESTINSNMOVEN1s("movz.d $f0, $f2, $t3", 8, 0xffff, f0, f2, t3); TESTINSNMOVEN1s("movz.d $f0, $f2, $t3", 12, -1, f0, f2, t3); TESTINSNMOVEN1s("movz.d $f0, $f2, $t3", 16, 5, f0, f2, t3); TESTINSNMOVEN1s("movz.d $f0, $f2, $t3", 20, 0, f0, f2, t3); TESTINSNMOVEN1s("movz.d $f0, $f2, $t3", 24, 0, f0, f2, t3); TESTINSNMOVEN1s("movz.d $f0, $f2, $t3", 28, 5, f0, f2, t3); TESTINSNMOVEN1s("movz.d $f0, $f2, $t3", 32, 125487, f0, f2, t3); TESTINSNMOVEN1s("movz.d $f0, $f2, $t3", 36, 68, f0, f2, t3); TESTINSNMOVEN1s("movz.d $f0, $f2, $t3", 40, -122544, f0, f2, t3); TESTINSNMOVEN1s("movz.d $f0, $f2, $t3", 44, 0, f0, f2, t3); TESTINSNMOVEN1s("movz.d $f0, $f2, $t3", 48, 0, f0, f2, t3); TESTINSNMOVEN1s("movz.d $f0, $f2, $t3", 52, 0xffffffff, f0, f2, t3); TESTINSNMOVEN1s("movz.d $f0, $f2, $t3", 56, 0x80000000, f0, f2, t3); TESTINSNMOVEN1s("movz.d $f0, $f2, $t3", 60, 0x7fffffff, f0, f2, t3); return 0; } #else int main() { return 0; } #endif