#if defined(__mips_hard_float)
typedef enum {
   TO_NEAREST=0,
   TO_ZERO,
   TO_PLUS_INFINITY,
   TO_MINUS_INFINITY
} round_mode_t;

char *round_mode_name[] = { "near", "zero", "+inf", "-inf" };

void set_rounding_mode(round_mode_t mode)
{
   switch(mode) {
      case TO_NEAREST:
         __asm__ __volatile__(
            "cfc1 $t0, $31"  "\n\t"
            "srl  $t0, 2"    "\n\t"
            "sll  $t0, 2"    "\n\t"
            "ctc1 $t0, $31"  "\n\t"
            :
            :
            : "t0"
         );
         break;
      case TO_ZERO:
         __asm__ __volatile__(
            "cfc1  $t0, $31"  "\n\t"
            "srl   $t0, 2"    "\n\t"
            "sll   $t0, 2"    "\n\t"
            "addiu $t0, 1"    "\n\t"
            "ctc1  $t0, $31"  "\n\t"
            :
            :
            : "t0"
         );
         break;
      case TO_PLUS_INFINITY:
         __asm__ __volatile__(
            "cfc1  $t0, $31"  "\n\t"
            "srl   $t0, 2"    "\n\t"
            "sll   $t0, 2"    "\n\t"
            "addiu $t0, 2"    "\n\t"
            "ctc1  $t0, $31"  "\n\t"
            :
            :
            : "t0"
         );
         break;
      case TO_MINUS_INFINITY:
         __asm__ __volatile__(
            "cfc1  $t0, $31"  "\n\t"
            "srl   $t0, 2"    "\n\t"
            "sll   $t0, 2"    "\n\t"
            "addiu $t0, 3"    "\n\t"
            "ctc1  $t0, $31"  "\n\t"
            :
            :
            : "t0"
         );
         break;
      }
}
#endif