| #include <assert.h> |
| |
| #define TEST_COMP(N) \ |
| void test_##N(float fj, float fk) \ |
| { \ |
| int rd = 0; \ |
| \ |
| asm volatile("fcmp."#N".s $fcc6,%1,%2\n" \ |
| "movcf2gr %0, $fcc6\n" \ |
| : "=r"(rd) \ |
| : "f"(fj), "f"(fk) \ |
| : ); \ |
| assert(rd == 1); \ |
| } |
| |
| TEST_COMP(ceq) |
| TEST_COMP(clt) |
| TEST_COMP(cle) |
| TEST_COMP(cne) |
| TEST_COMP(seq) |
| TEST_COMP(slt) |
| TEST_COMP(sle) |
| TEST_COMP(sne) |
| |
| int main() |
| { |
| test_ceq(0xff700102, 0xff700102); |
| test_clt(0x00730007, 0xff730007); |
| test_cle(0xff70130a, 0xff70130b); |
| test_cne(0x1238acde, 0xff71111f); |
| test_seq(0xff766618, 0xff766619); |
| test_slt(0xff78881c, 0xff78901d); |
| test_sle(0xff780b22, 0xff790b22); |
| test_sne(0xff7bcd25, 0xff7a26cf); |
| |
| return 0; |
| } |