#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;
}