#include <stdio.h> #if defined(__mips_hard_float) #define TESTINST_CFC1_CTC1(N) \ { \ unsigned int out = 0; \ __asm__ __volatile__( \ "move $t0, %1" "\n\t" \ "ctc1 $t0, $31" "\n\t" \ "cfc1 $t1, $31" "\n\t" \ "move %0, $t1" "\n\t" \ : "=r" (out) \ : "r" (N) \ : "t0", "t1" \ ); \ printf("out=%d, in=%d\n", out, N); \ } #else #define TESTINST_CFC1_CTC1(N) #endif int main() { int i; printf("--- CTC1, CFC1 ---\n"); for (i = 0; i < 1024; i++) { TESTINST_CFC1_CTC1(i); } return 0; }