* mn10300-dis.c (print_insn_mn10300): 0xf9 opcode prefix specifies
[deliverable/binutils-gdb.git] / opcodes / mips-dis.c
index 745b6bfb61e4dfc4d8aa16ffa89198fd5bf266a3..4efd91c6a6f2705dea3a44fdaaca054f75b16e9b 100644 (file)
@@ -1,5 +1,5 @@
 /* Print mips instructions for GDB, the GNU debugger, or for objdump.
-   Copyright 1989, 91, 92, 93, 94, 95, 1996 Free Software Foundation, Inc.
+   Copyright (c) 1989, 91-97, 1998 Free Software Foundation, Inc.
    Contributed by Nobuyuki Hikichi(hikichi@sra.co.jp).
 
 This file is part of GDB, GAS, and the GNU binutils.
@@ -22,11 +22,18 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
 #include "sysdep.h"
 #include "dis-asm.h"
 #include "opcode/mips.h"
+#include "opintl.h"
 
-/* FIXME: These are needed to figure out if this is a mips16 symbol or
-   not.  It would be better to think of a cleaner way to do this.  */
+/* FIXME: These are needed to figure out if the code is mips16 or
+   not. The low bit of the address is often a good indicator.  No
+   symbol table is available when this code runs out in an embedded
+   system as when it is used for disassembler support in a monitor. */
+
+#if !defined(EMBEDDED_ENV)
+#define SYMTAB_AVAILABLE 1
 #include "elf-bfd.h"
 #include "elf/mips.h"
+#endif
 
 static int print_insn_mips16 PARAMS ((bfd_vma, struct disassemble_info *));
 static void print_mips16_insn_arg
@@ -80,6 +87,14 @@ print_insn_arg (d, l, pc, info)
     case ',':
     case '(':
     case ')':
+      /* start-sanitize-vr5400 */
+    case '[':
+    case ']':
+      /* end-sanitize-vr5400 */
+      /* start-sanitize-r5900 */
+    case '+':
+    case '-':
+      /* end-sanitize-r5900 */
       (*info->fprintf_func) (info->stream, "%c", *d);
       break;
 
@@ -159,6 +174,12 @@ print_insn_arg (d, l, pc, info)
                             (l >> OP_SH_CODE) & OP_MASK_CODE);
       break;
 
+
+    case 'q':
+      (*info->fprintf_func) (info->stream, "0x%x",
+                            (l >> OP_SH_CODE2) & OP_MASK_CODE2);
+      break;
+
     case 'C':
       (*info->fprintf_func) (info->stream, "0x%x",
                             (l >> OP_SH_COPZ) & OP_MASK_COPZ);
@@ -175,6 +196,124 @@ print_insn_arg (d, l, pc, info)
                             (l >> OP_SH_FS) & OP_MASK_FS);
       break;
 
+    /* start-sanitize-r5900 */
+    case '0':
+      (*info->fprintf_func) (info->stream, "0x%x",
+                             (l >> 6) & 0x1f);
+      break;
+
+    case '9':
+      (*info->fprintf_func) (info->stream, "vi27");
+      break;
+
+    case '1':
+      (*info->fprintf_func) (info->stream, "vf%d",
+                            (l >> OP_SH_FT) & OP_MASK_FT);
+      break;
+    case '2':
+      (*info->fprintf_func) (info->stream, "vf%d",
+                            (l >> OP_SH_FS) & OP_MASK_FS);
+      break;
+    case '3':
+      (*info->fprintf_func) (info->stream, "vf%d",
+                            (l >> OP_SH_FD) & OP_MASK_FD);
+      break;
+
+    case '4':
+      (*info->fprintf_func) (info->stream, "vi%d",
+                            (l >> OP_SH_FT) & OP_MASK_FT);
+      break;
+    case '5':
+      (*info->fprintf_func) (info->stream, "vi%d",
+                            (l >> OP_SH_FS) & OP_MASK_FS);
+      break;
+    case '6':
+      (*info->fprintf_func) (info->stream, "vi%d",
+                            (l >> OP_SH_FD) & OP_MASK_FD);
+      break;
+
+    case '7':
+      (*info->fprintf_func) (info->stream, "vf%d",
+                            (l >> OP_SH_FT) & OP_MASK_FT);
+      switch ((l >> 23) & 0x3)
+       {
+         case 0:
+           (*info->fprintf_func) (info->stream, "x");
+           break;
+         case 1:
+           (*info->fprintf_func) (info->stream, "y");
+           break;
+         case 2:
+           (*info->fprintf_func) (info->stream, "z");
+           break;
+         case 3:
+           (*info->fprintf_func) (info->stream, "w");
+           break;
+       }
+      break;
+    case 'K':
+      break;
+
+    case ';':
+      (*info->fprintf_func) (info->stream, ".xyz\t");
+      break;
+       
+    case '&':
+      (*info->fprintf_func) (info->stream, ".");
+      if (l & (1 << 21))
+       (*info->fprintf_func) (info->stream, "w");
+      if (l & (1 << 24))
+       (*info->fprintf_func) (info->stream, "x");
+      if (l & (1 << 23))
+       (*info->fprintf_func) (info->stream, "y");
+      if (l & (1 << 22))
+       (*info->fprintf_func) (info->stream, "z");
+      (*info->fprintf_func) (info->stream, "\t");
+      break;
+       
+    case '8':
+      (*info->fprintf_func) (info->stream, "vf%d",
+                            (l >> OP_SH_FS) & OP_MASK_FS);
+      switch ((l >> 21) & 0x3)
+       {
+         case 0:
+           (*info->fprintf_func) (info->stream, "x");
+           break;
+         case 1:
+           (*info->fprintf_func) (info->stream, "y");
+           break;
+         case 2:
+           (*info->fprintf_func) (info->stream, "z");
+           break;
+         case 3:
+           (*info->fprintf_func) (info->stream, "w");
+           break;
+       }
+      break;
+    case 'J':
+      (*info->fprintf_func) (info->stream, "I");
+      break;
+
+    case 'Q':
+      (*info->fprintf_func) (info->stream, "Q");
+      break;
+
+    case 'X':
+      (*info->fprintf_func) (info->stream, "R");
+      break;
+
+    case 'U':
+      (*info->fprintf_func) (info->stream, "ACC");
+      break;
+
+    case 'O':
+      delta = (l >> 6) & 0x7fff;
+      delta <<= 3;
+      (*info->print_address_func) (delta, info);
+      break;
+
+    /* end-sanitize-r5900 */
+
     case 'T':
     case 'W':
       (*info->fprintf_func) (info->stream, "$f%d",
@@ -211,13 +350,147 @@ print_insn_arg (d, l, pc, info)
                             (l >> OP_SH_CCC) & OP_MASK_CCC);
       break;
 
+    case 'P':
+      (*info->fprintf_func) (info->stream, "%d",
+                            (l >> OP_SH_PERFREG) & OP_MASK_PERFREG);
+      break;
+
+      /* start-sanitize-vr5400 */
+    case 'e':
+      (*info->fprintf_func) (info->stream, "%d",
+                            (l >> OP_SH_VECBYTE) & OP_MASK_VECBYTE);
+      break;
+
+    case '%':
+      (*info->fprintf_func) (info->stream, "%d",
+                            (l >> OP_SH_VECALIGN) & OP_MASK_VECALIGN);
+      break;
+      /* end-sanitize-vr5400 */
+
     default:
+      /* xgettext:c-format */
       (*info->fprintf_func) (info->stream,
-                            "# internal error, undefined modifier(%c)", *d);
+                            _("# internal error, undefined modifier(%c)"),
+                            *d);
       break;
     }
 }
 \f
+#if SYMTAB_AVAILABLE
+
+/* Figure out the MIPS ISA and CPU based on the machine number.
+   FIXME: What does this have to do with SYMTAB_AVAILABLE?  */
+
+static void
+set_mips_isa_type (mach, isa, cputype)
+     int mach;
+     int *isa;
+     int *cputype;
+{
+  int target_processor = 0;
+  int mips_isa = 0;
+
+  switch (mach)
+    {
+      /* start-sanitize-tx19 */
+      case bfd_mach_mips1900:
+       target_processor = 1900;
+       mips_isa = 1;
+       break;
+      /* end-sanitize-tx19 */
+      case bfd_mach_mips3000:
+       target_processor = 3000;
+       mips_isa = 1;
+       break;
+      case bfd_mach_mips3900:
+       target_processor = 3900;
+       mips_isa = 1;
+       break;
+      case bfd_mach_mips4000:
+       target_processor = 4000;
+       mips_isa = 3;
+       break;
+      case bfd_mach_mips4010:
+       target_processor = 4010;
+       mips_isa = 2;
+       break;
+      case bfd_mach_mips4100:
+       target_processor = 4100;
+       mips_isa = 3;
+       break;
+      case bfd_mach_mips4300:
+       target_processor = 4300;
+       mips_isa = 3;
+       break;
+       /* start-sanitize-vr4320 */
+      case bfd_mach_mips4320:
+       target_processor = 4320;
+       mips_isa = 3;
+       break;
+       /* end-sanitize-vr4320 */
+      case bfd_mach_mips4400:
+       target_processor = 4400;
+       mips_isa = 3;
+       break;
+      case bfd_mach_mips4600:
+       target_processor = 4600;
+       mips_isa = 3;
+       break;
+      case bfd_mach_mips4650:
+       target_processor = 4650;
+       mips_isa = 3;
+       break;
+      /* start-sanitize-tx49 */
+      case bfd_mach_mips4900:
+       target_processor = 4900;
+       mips_isa = 3;
+       break;
+      /* end-sanitize-tx49 */
+      case bfd_mach_mips5000:
+       target_processor = 5000;
+       mips_isa = 4;
+       break;
+      /* start-sanitize-vr5400 */
+      case bfd_mach_mips5400:
+       target_processor = 5400;
+       mips_isa = 3;
+       break;
+      /* end-sanitize-vr5400 */
+      /* start-sanitize-r5900 */
+      case bfd_mach_mips5900:
+       target_processor = 5900;
+       mips_isa = 3;
+       break;
+      /* end-sanitize-r5900 */
+      case bfd_mach_mips6000:
+       target_processor = 6000;
+       mips_isa = 2;
+       break;
+      case bfd_mach_mips8000:
+       target_processor = 8000;
+       mips_isa = 4;
+       break;
+      case bfd_mach_mips10000:
+       target_processor = 10000;
+       mips_isa = 4;
+       break;
+      case bfd_mach_mips16:
+       target_processor = 16;
+       mips_isa = 3;
+       break;
+      default:
+       target_processor = 3000;
+       mips_isa = 3;
+       break;
+
+    }
+
+  *isa = mips_isa;
+  *cputype = target_processor;
+}
+
+#endif /* SYMTAB_AVAILABLE */
+
 /* Print the mips instruction at address MEMADDR in debugged memory,
    on using INFO.  Returns length of the instruction, in bytes, which is
    always 4.  BIGENDIAN must be 1 if this is big-endian code, 0 if
@@ -230,6 +503,7 @@ _print_insn_mips (memaddr, word, info)
      struct disassemble_info *info;
 {
   register const struct mips_opcode *op;
+  int target_processor, mips_isa;
   static boolean init = 0;
   static const struct mips_opcode *mips_hash[OP_MASK_OP + 1];
 
@@ -255,6 +529,18 @@ _print_insn_mips (memaddr, word, info)
       init = 1;
     }
 
+#if ! SYMTAB_AVAILABLE
+  /* This is running out on a target machine, not in a host tool.
+     FIXME: Where does mips_target_info come from?  */
+  target_processor = mips_target_info.processor;
+  mips_isa = mips_target_info.isa;
+#else  
+  set_mips_isa_type (info->mach, &target_processor, &mips_isa);
+#endif  
+
+  info->bytes_per_chunk = 4;
+  info->display_endian = info->endian;
+
   op = mips_hash[(word >> OP_SH_OP) & OP_MASK_OP];
   if (op != NULL)
     {
@@ -263,15 +549,69 @@ _print_insn_mips (memaddr, word, info)
          if (op->pinfo != INSN_MACRO && (word & op->mask) == op->match)
            {
              register const char *d;
+             int insn_isa;
+
+             if ((op->membership & INSN_ISA) == INSN_ISA1)
+               insn_isa = 1;
+             else if ((op->membership & INSN_ISA) == INSN_ISA2)
+               insn_isa = 2;
+             else if ((op->membership & INSN_ISA) == INSN_ISA3)
+               insn_isa = 3;
+             else if ((op->membership & INSN_ISA) == INSN_ISA4)
+               insn_isa = 4;
+             else
+               insn_isa = 15;
+
+             if (insn_isa > mips_isa
+                 && (target_processor == 4650
+                     && op->membership & INSN_4650) == 0
+                 && (target_processor == 4010
+                     && op->membership & INSN_4010) == 0
+                 && (target_processor == 4100
+                     && op->membership & INSN_4100) == 0
+                 /* start-sanitize-vr4320 */
+                 && (target_processor == 4320
+                     && op->membership & INSN_4320) == 0
+                 /* end-sanitize-vr4320 */
+                 /* start-sanitize-vr5400 */
+                 && (target_processor == 5400
+                     && op->membership & INSN_5400) == 0
+                 /* end-sanitize-vr5400 */
+                 /* start-sanitize-r5900 */
+                 && (target_processor == 5900
+                     && op->membership & INSN_5900) == 0
+                 /* end-sanitize-r5900 */
+                 /* start-sanitize-tx49 */
+                 && (target_processor == 4900
+                     && op->membership & INSN_4900) == 0
+                 /* end-sanitize-tx49 */
+                 && (target_processor == 3900
+                     && op->membership & INSN_3900) == 0)
+               continue;
 
              (*info->fprintf_func) (info->stream, "%s", op->name);
 
              d = op->args;
              if (d != NULL && *d != '\0')
                {
-                 (*info->fprintf_func) (info->stream, "\t");
+                 /* start-sanitize-r5900 */
+                 /* If this is an opcode completer, then do not emit
+                    a tab after the opcode.  */
+                 if (*d != '&' && *d != ';')
+                 /* end-sanitize-r5900 */
+                   (*info->fprintf_func) (info->stream, "\t");
                  for (; *d != '\0'; d++)
-                   print_insn_arg (d, word, memaddr, info);
+                   /* start-sanitize-r5900 */
+                   /* If this is an escape character, go ahead and print the
+                      next character in the arg string verbatim.  */
+                   if (*d == '#')
+                     {
+                       d++;
+                       (*info->fprintf_func) (info->stream, "%c", *d);
+                     }
+                   else
+                   /* end-sanitize-r5900 */
+                     print_insn_arg (d, word, memaddr, info);
                }
 
              return 4;
@@ -284,6 +624,13 @@ _print_insn_mips (memaddr, word, info)
   return 4;
 }
 
+
+/* In an environment where we do not know the symbol type of the
+   instruction we are forced to assume that the low order bit of the
+   instructions' address may mark it as a mips16 instruction.  If we
+   are single stepping, or the pc is within the disassembled function,
+   this works.  Otherwise, we need a clue.  Sometimes.  */
+
 int
 print_insn_big_mips (memaddr, info)
      bfd_vma memaddr;
@@ -292,12 +639,21 @@ print_insn_big_mips (memaddr, info)
   bfd_byte buffer[4];
   int status;
 
+#if 1
+  /* FIXME: If odd address, this is CLEARLY a mips 16 instruction.  */
+  /* Only a few tools will work this way.  */
+  if (memaddr & 0x01)
+    return print_insn_mips16 (memaddr, info);
+#endif  
+
+#if SYMTAB_AVAILABLE
   if (info->mach == 16
       || (info->flavour == bfd_target_elf_flavour
-         && info->symbol != NULL
-         && (((elf_symbol_type *) info->symbol)->internal_elf_sym.st_other
+         && info->symbols != NULL
+         && ((*(elf_symbol_type **) info->symbols)->internal_elf_sym.st_other
              == STO_MIPS16)))
     return print_insn_mips16 (memaddr, info);
+#endif  
 
   status = (*info->read_memory_func) (memaddr, buffer, 4, info);
   if (status == 0)
@@ -318,12 +674,34 @@ print_insn_little_mips (memaddr, info)
   bfd_byte buffer[4];
   int status;
 
+  /* start-sanitize-sky */
+#ifdef ARCH_dvp
+  {
+    /* bfd_mach_dvp_p is a macro which may evaluate its arguments more than
+       once.  Since dvp_mach_type is a function, ensure it's only called
+       once.  */
+    int mach = dvp_info_mach_type (info);
+
+    if (bfd_mach_dvp_p (info->mach)
+       || bfd_mach_dvp_p (mach))
+      return print_insn_dvp (memaddr, info);
+  }
+#endif
+  /* end-sanitize-sky */
+
+#if 1
+  if (memaddr & 0x01)
+    return print_insn_mips16 (memaddr, info);
+#endif  
+
+#if SYMTAB_AVAILABLE
   if (info->mach == 16
       || (info->flavour == bfd_target_elf_flavour
-         && info->symbol != NULL
-         && (((elf_symbol_type *) info->symbol)->internal_elf_sym.st_other
+         && info->symbols != NULL
+         && ((*(elf_symbol_type **) info->symbols)->internal_elf_sym.st_other
              == STO_MIPS16)))
     return print_insn_mips16 (memaddr, info);
+#endif  
 
   status = (*info->read_memory_func) (memaddr, buffer, 4, info);
   if (status == 0)
@@ -348,9 +726,19 @@ print_insn_mips16 (memaddr, info)
   int length;
   int insn;
   boolean use_extend;
-  int extend;
+  int extend = 0;
   const struct mips_opcode *op, *opend;
 
+  info->bytes_per_chunk = 2;
+  info->display_endian = info->endian;
+
+  info->insn_info_valid = 1;
+  info->branch_delay_insns = 0;
+  info->data_size = 0;
+  info->insn_type = dis_nonbranch;
+  info->target = 0;
+  info->target2 = 0;
+
   status = (*info->read_memory_func) (memaddr, buffer, 2, info);
   if (status != 0)
     {
@@ -393,6 +781,7 @@ print_insn_mips16 (memaddr, info)
        {
          (*info->fprintf_func) (info->stream, "extend 0x%x",
                                 (unsigned int) extend);
+         info->insn_type = dis_noninsn;
          return length;
        }
 
@@ -414,6 +803,7 @@ print_insn_mips16 (memaddr, info)
                {
                  (*info->fprintf_func) (info->stream, "extend 0x%x",
                                         (unsigned int) extend);
+                 info->insn_type = dis_noninsn;
                  return length - 2;
                }
 
@@ -462,6 +852,13 @@ print_insn_mips16 (memaddr, info)
                                     info);
            }
 
+         if ((op->pinfo & INSN_UNCOND_BRANCH_DELAY) != 0)
+           {
+             info->branch_delay_insns = 1;
+             if (info->insn_type != dis_jsr)
+               info->insn_type = dis_branch;
+           }
+
          return length;
        }
     }
@@ -469,6 +866,7 @@ print_insn_mips16 (memaddr, info)
   if (use_extend)
     (*info->fprintf_func) (info->stream, "0x%x", extend | 0xf000);
   (*info->fprintf_func) (info->stream, "0x%x", insn);
+  info->insn_type = dis_noninsn;
 
   return length;
 }
@@ -612,21 +1010,33 @@ print_mips16_insn_arg (type, op, l, use_extend, extend, memaddr, info)
          case '5':
            nbits = 5;
            immed = (l >> MIPS16OP_SH_IMM5) & MIPS16OP_MASK_IMM5;
+           info->insn_type = dis_dref;
+           info->data_size = 1;
            break;
          case 'H':
            nbits = 5;
            shift = 1;
            immed = (l >> MIPS16OP_SH_IMM5) & MIPS16OP_MASK_IMM5;
+           info->insn_type = dis_dref;
+           info->data_size = 2;
            break;
          case 'W':
            nbits = 5;
            shift = 2;
            immed = (l >> MIPS16OP_SH_IMM5) & MIPS16OP_MASK_IMM5;
+           if ((op->pinfo & MIPS16_INSN_READ_PC) == 0
+               && (op->pinfo & MIPS16_INSN_READ_SP) == 0)
+             {
+               info->insn_type = dis_dref;
+               info->data_size = 4;
+             }
            break;
          case 'D':
            nbits = 5;
            shift = 3;
            immed = (l >> MIPS16OP_SH_IMM5) & MIPS16OP_MASK_IMM5;
+           info->insn_type = dis_dref;
+           info->data_size = 8;
            break;
          case 'j':
            nbits = 5;
@@ -645,11 +1055,17 @@ print_mips16_insn_arg (type, op, l, use_extend, extend, memaddr, info)
            nbits = 8;
            shift = 2;
            immed = (l >> MIPS16OP_SH_IMM8) & MIPS16OP_MASK_IMM8;
+           /* FIXME: This might be lw, or it might be addiu to $sp or
+               $pc.  We assume it's load.  */
+           info->insn_type = dis_dref;
+           info->data_size = 4;
            break;
          case 'C':
            nbits = 8;
            shift = 3;
            immed = (l >> MIPS16OP_SH_IMM8) & MIPS16OP_MASK_IMM8;
+           info->insn_type = dis_dref;
+           info->data_size = 8;
            break;
          case 'U':
            nbits = 8;
@@ -673,6 +1089,7 @@ print_mips16_insn_arg (type, op, l, use_extend, extend, memaddr, info)
            signedp = 1;
            pcrel = 1;
            branch = 1;
+           info->insn_type = dis_condbranch;
            break;
          case 'q':
            nbits = 11;
@@ -680,18 +1097,24 @@ print_mips16_insn_arg (type, op, l, use_extend, extend, memaddr, info)
            signedp = 1;
            pcrel = 1;
            branch = 1;
+           info->insn_type = dis_branch;
            break;
          case 'A':
            nbits = 8;
            shift = 2;
            immed = (l >> MIPS16OP_SH_IMM8) & MIPS16OP_MASK_IMM8;
            pcrel = 1;
+           /* FIXME: This can be lw or la.  We assume it is lw.  */
+           info->insn_type = dis_dref;
+           info->data_size = 4;
            break;
          case 'B':
            nbits = 5;
            shift = 3;
            immed = (l >> MIPS16OP_SH_IMM5) & MIPS16OP_MASK_IMM5;
            pcrel = 1;
+           info->insn_type = dis_dref;
+           info->data_size = 8;
            break;
          case 'E':
            nbits = 5;
@@ -708,7 +1131,7 @@ print_mips16_insn_arg (type, op, l, use_extend, extend, memaddr, info)
            if (signedp && immed >= (1 << (nbits - 1)))
              immed -= 1 << nbits;
            immed <<= shift;
-           if ((type == '<' || type == '>' || type == '[' || type == '[')
+           if ((type == '<' || type == '>' || type == '[' || type == ']')
                && immed == 0)
              immed = 8;
          }
@@ -738,7 +1161,7 @@ print_mips16_insn_arg (type, op, l, use_extend, extend, memaddr, info)
                baseaddr = memaddr + 2;
              }
            else if (use_extend)
-             baseaddr = memaddr;
+             baseaddr = memaddr - 2;
            else
              {
                int status;
@@ -775,6 +1198,7 @@ print_mips16_insn_arg (type, op, l, use_extend, extend, memaddr, info)
              }
            val = (baseaddr & ~ ((1 << shift) - 1)) + immed;
            (*info->print_address_func) (val, info);
+           info->target = val;
          }
       }
       break;
@@ -784,6 +1208,9 @@ print_mips16_insn_arg (type, op, l, use_extend, extend, memaddr, info)
        extend = 0;
       l = ((l & 0x1f) << 23) | ((l & 0x3e0) << 13) | (extend << 2);
       (*info->print_address_func) ((memaddr & 0xf0000000) | l, info);
+      info->insn_type = dis_jsr;
+      info->target = (memaddr & 0xf0000000) | l;
+      info->branch_delay_insns = 1;
       break;
 
     case 'l':
@@ -796,16 +1223,12 @@ print_mips16_insn_arg (type, op, l, use_extend, extend, memaddr, info)
        l = (l >> MIPS16OP_SH_IMM6) & MIPS16OP_MASK_IMM6;
 
        amask = (l >> 3) & 7;
-       if (amask == 5 || amask == 6)
-         {
-           (*info->fprintf_func) (info->stream, "??");
-           need_comma = 1;
-         }
-       else if (amask > 0 && amask < 7)
+
+       if (amask > 0 && amask < 5)
          {
-           (*info->fprintf_func) (info->stream, "%s", reg_names[4]);
+           (*info->fprintf_func) (info->stream, "$%s", reg_names[4]);
            if (amask > 1)
-             (*info->fprintf_func) (info->stream, "-%s",
+             (*info->fprintf_func) (info->stream, "-$%s",
                                     reg_names[amask + 3]);
            need_comma = 1;
          }
@@ -819,19 +1242,30 @@ print_mips16_insn_arg (type, op, l, use_extend, extend, memaddr, info)
          }
        else if (smask > 0)
          {
-           (*info->fprintf_func) (info->stream, "%s%s",
+           (*info->fprintf_func) (info->stream, "%s$%s",
                                   need_comma ? "," : "",
                                   reg_names[16]);
            if (smask > 1)
-             (*info->fprintf_func) (info->stream, "-%s",
+             (*info->fprintf_func) (info->stream, "-$%s",
                                     reg_names[smask + 15]);
            need_comma = 1;
          }
 
        if (l & 1)
-         (*info->fprintf_func) (info->stream, "%s%s",
-                                need_comma ? "," : "",
-                                reg_names[31]);
+         {
+           (*info->fprintf_func) (info->stream, "%s$%s",
+                                  need_comma ? "," : "",
+                                  reg_names[31]);
+           need_comma = 1;
+         }
+
+       if (amask == 5 || amask == 6)
+         {
+           (*info->fprintf_func) (info->stream, "%s$f0",
+                                  need_comma ? "," : "");
+           if (amask == 6)
+             (*info->fprintf_func) (info->stream, "-$f1");
+         }
       }
       break;
 
This page took 0.032883 seconds and 4 git commands to generate.