Add startswith function and use it instead of CONST_STRNEQ.
[deliverable/binutils-gdb.git] / opcodes / i386-dis.c
index 98d340c05ba0315052203d1ad9291a5ad4662635..9e5c412fa4adaee94a1f9e19c748b467a138405e 100644 (file)
@@ -411,9 +411,7 @@ fetch_data (struct disassemble_info *info, bfd_byte *addr)
 #define MaskVex { OP_VEX, mask_mode }
 
 #define MVexVSIBDWpX { OP_M, vex_vsib_d_w_dq_mode }
-#define MVexVSIBDQWpX { OP_M, vex_vsib_d_w_d_mode }
 #define MVexVSIBQWpX { OP_M, vex_vsib_q_w_dq_mode }
-#define MVexVSIBQDWpX { OP_M, vex_vsib_q_w_d_mode }
 
 #define MVexSIBMEM { OP_M, vex_sibmem_mode }
 
@@ -555,12 +553,8 @@ enum
 
   /* Operand size depends on the VEX.W bit, with VSIB dword indices.  */
   vex_vsib_d_w_dq_mode,
-  /* Similar to vex_vsib_d_w_dq_mode, with smaller memory.  */
-  vex_vsib_d_w_d_mode,
   /* Operand size depends on the VEX.W bit, with VSIB qword indices.  */
   vex_vsib_q_w_dq_mode,
-  /* Similar to vex_vsib_q_w_dq_mode, with smaller memory.  */
-  vex_vsib_q_w_d_mode,
   /* mandatory non-vector SIB.  */
   vex_sibmem_mode,
 
@@ -717,8 +711,7 @@ enum
   REG_EVEX_0F72,
   REG_EVEX_0F73,
   REG_EVEX_0F38C6_M_0_L_2,
-  REG_EVEX_0F38C7_M_0_L_2_W_0,
-  REG_EVEX_0F38C7_M_0_L_2_W_1
+  REG_EVEX_0F38C7_M_0_L_2
 };
 
 enum
@@ -1598,11 +1591,6 @@ enum
   EVEX_W_0F387A,
   EVEX_W_0F387B,
   EVEX_W_0F3883,
-  EVEX_W_0F3891,
-  EVEX_W_0F3893,
-  EVEX_W_0F38A1,
-  EVEX_W_0F38A3,
-  EVEX_W_0F38C7_M_0_L_2,
 
   EVEX_W_0F3A05,
   EVEX_W_0F3A08,
@@ -9425,38 +9413,38 @@ print_insn (bfd_vma pc, disassemble_info *info)
 
   for (p = info->disassembler_options; p != NULL; )
     {
-      if (CONST_STRNEQ (p, "amd64"))
+      if (startswith (p, "amd64"))
        isa64 = amd64;
-      else if (CONST_STRNEQ (p, "intel64"))
+      else if (startswith (p, "intel64"))
        isa64 = intel64;
-      else if (CONST_STRNEQ (p, "x86-64"))
+      else if (startswith (p, "x86-64"))
        {
          address_mode = mode_64bit;
          priv.orig_sizeflag |= AFLAG | DFLAG;
        }
-      else if (CONST_STRNEQ (p, "i386"))
+      else if (startswith (p, "i386"))
        {
          address_mode = mode_32bit;
          priv.orig_sizeflag |= AFLAG | DFLAG;
        }
-      else if (CONST_STRNEQ (p, "i8086"))
+      else if (startswith (p, "i8086"))
        {
          address_mode = mode_16bit;
          priv.orig_sizeflag &= ~(AFLAG | DFLAG);
        }
-      else if (CONST_STRNEQ (p, "intel"))
+      else if (startswith (p, "intel"))
        {
          intel_syntax = 1;
-         if (CONST_STRNEQ (p + 5, "-mnemonic"))
+         if (startswith (p + 5, "-mnemonic"))
            intel_mnemonic = 1;
        }
-      else if (CONST_STRNEQ (p, "att"))
+      else if (startswith (p, "att"))
        {
          intel_syntax = 0;
-         if (CONST_STRNEQ (p + 3, "-mnemonic"))
+         if (startswith (p + 3, "-mnemonic"))
            intel_mnemonic = 0;
        }
-      else if (CONST_STRNEQ (p, "addr"))
+      else if (startswith (p, "addr"))
        {
          if (address_mode == mode_64bit)
            {
@@ -9473,14 +9461,14 @@ print_insn (bfd_vma pc, disassemble_info *info)
                priv.orig_sizeflag |= AFLAG;
            }
        }
-      else if (CONST_STRNEQ (p, "data"))
+      else if (startswith (p, "data"))
        {
          if (p[4] == '1' && p[5] == '6')
            priv.orig_sizeflag &= ~DFLAG;
          else if (p[4] == '3' && p[5] == '2')
            priv.orig_sizeflag |= DFLAG;
        }
-      else if (CONST_STRNEQ (p, "suffix"))
+      else if (startswith (p, "suffix"))
        priv.orig_sizeflag |= SUFFIX_ALWAYS;
 
       p = strchr (p, ',');
@@ -9795,7 +9783,7 @@ print_insn (bfd_vma pc, disassemble_info *info)
         origins in all_prefixes.  */
       used_prefixes &= ~PREFIX_OPCODE;
       if (last_data_prefix >= 0)
-       all_prefixes[last_repz_prefix] = 0x66;
+       all_prefixes[last_data_prefix] = 0x66;
       if (last_repz_prefix >= 0)
        all_prefixes[last_repz_prefix] = 0xf3;
       if (last_repnz_prefix >= 0)
@@ -10761,7 +10749,7 @@ putop (const char *in_template, int sizeflag)
            }
          else if (l == 1 && last[0] == 'X')
            {
-             if (!need_vex || !vex.evex)
+             if (!vex.evex)
                abort ();
              if (intel_syntax
                  || ((modrm.mod == 3 || vex.b) && !(sizeflag & SUFFIX_ALWAYS)))
@@ -10963,8 +10951,7 @@ print_displacement (char *buf, bfd_vma disp)
 static void
 intel_operand_size (int bytemode, int sizeflag)
 {
-  if (vex.evex
-      && vex.b
+  if (vex.b
       && (bytemode == x_mode
          || bytemode == evex_half_bcst_xmmq_mode))
     {
@@ -11263,51 +11250,10 @@ intel_operand_size (int bytemode, int sizeflag)
       if (!need_vex)
        abort ();
 
-      if (!vex.evex)
-       {
-         if (vex.w)
-           oappend ("QWORD PTR ");
-         else
-           oappend ("DWORD PTR ");
-       }
+      if (vex.w)
+       oappend ("QWORD PTR ");
       else
-       {
-         switch (vex.length)
-           {
-           case 128:
-             oappend ("XMMWORD PTR ");
-             break;
-           case 256:
-             oappend ("YMMWORD PTR ");
-             break;
-           case 512:
-             oappend ("ZMMWORD PTR ");
-             break;
-           default:
-             abort ();
-           }
-       }
-      break;
-    case vex_vsib_q_w_d_mode:
-    case vex_vsib_d_w_d_mode:
-      if (!need_vex || !vex.evex)
-       abort ();
-
-      switch (vex.length)
-       {
-       case 128:
-         oappend ("QWORD PTR ");
-         break;
-       case 256:
-         oappend ("XMMWORD PTR ");
-         break;
-       case 512:
-         oappend ("YMMWORD PTR ");
-         break;
-       default:
-         abort ();
-       }
-
+       oappend ("DWORD PTR ");
       break;
     case mask_bd_mode:
       if (!need_vex || vex.length != 128)
@@ -11471,7 +11417,6 @@ OP_E_memory (int bytemode, int sizeflag)
       /* In EVEX, if operand doesn't allow broadcast, vex.b should be 0.  */
       if (vex.b
          && bytemode != x_mode
-         && bytemode != xmmq_mode
          && bytemode != evex_half_bcst_xmmq_mode)
        {
          BadOp ();
@@ -11502,15 +11447,12 @@ OP_E_memory (int bytemode, int sizeflag)
            /* fall through */
        case vex_scalar_w_dq_mode:
        case vex_vsib_d_w_dq_mode:
-       case vex_vsib_d_w_d_mode:
        case vex_vsib_q_w_dq_mode:
-       case vex_vsib_q_w_d_mode:
        case evex_x_gscat_mode:
          shift = vex.w ? 3 : 2;
          break;
        case x_mode:
        case evex_half_bcst_xmmq_mode:
-       case xmmq_mode:
          if (vex.b)
            {
              shift = vex.w ? 3 : 2;
@@ -11519,6 +11461,7 @@ OP_E_memory (int bytemode, int sizeflag)
          /* Fall through.  */
        case xmmqd_mode:
        case xmmdw_mode:
+       case xmmq_mode:
        case ymmq_mode:
        case evex_x_nobcst_mode:
        case x_swap_mode:
@@ -11607,9 +11550,7 @@ OP_E_memory (int bytemode, int sizeflag)
          switch (bytemode)
            {
            case vex_vsib_d_w_dq_mode:
-           case vex_vsib_d_w_d_mode:
            case vex_vsib_q_w_dq_mode:
-           case vex_vsib_q_w_d_mode:
              if (!need_vex)
                abort ();
              if (vex.evex)
@@ -11626,16 +11567,14 @@ OP_E_memory (int bytemode, int sizeflag)
                  break;
                case 256:
                  if (!vex.w
-                     || bytemode == vex_vsib_q_w_dq_mode
-                     || bytemode == vex_vsib_q_w_d_mode)
+                     || bytemode == vex_vsib_q_w_dq_mode)
                    indexes64 = indexes32 = names_ymm;
                  else
                    indexes64 = indexes32 = names_xmm;
                  break;
                case 512:
                  if (!vex.w
-                     || bytemode == vex_vsib_q_w_dq_mode
-                     || bytemode == vex_vsib_q_w_d_mode)
+                     || bytemode == vex_vsib_q_w_dq_mode)
                    indexes64 = indexes32 = names_zmm;
                  else
                    indexes64 = indexes32 = names_ymm;
@@ -11905,13 +11844,11 @@ OP_E_memory (int bytemode, int sizeflag)
          oappend (scratchbuf);
        }
     }
-  if (vex.evex && vex.b
+  if (vex.b
       && (bytemode == x_mode
-         || bytemode == xmmq_mode
          || bytemode == evex_half_bcst_xmmq_mode))
     {
       if (vex.w
-         || bytemode == xmmq_mode
          || bytemode == evex_half_bcst_xmmq_mode)
        {
          switch (vex.length)
@@ -12661,36 +12598,8 @@ OP_XMM (int bytemode, int sizeflag ATTRIBUTE_UNUSED)
        reg += 16;
     }
 
-  if (need_vex
-      && bytemode != xmm_mode
-      && bytemode != xmmq_mode
-      && bytemode != evex_half_bcst_xmmq_mode
-      && bytemode != ymm_mode
-      && bytemode != tmm_mode
-      && bytemode != scalar_mode)
-    {
-      switch (vex.length)
-       {
-       case 128:
-         names = names_xmm;
-         break;
-       case 256:
-         if (vex.w
-             || (bytemode != vex_vsib_q_w_dq_mode
-                 && bytemode != vex_vsib_q_w_d_mode))
-           names = names_ymm;
-         else
-           names = names_xmm;
-         break;
-       case 512:
-         names = names_zmm;
-         break;
-       default:
-         abort ();
-       }
-    }
-  else if (bytemode == xmmq_mode
-          || bytemode == evex_half_bcst_xmmq_mode)
+  if (bytemode == xmmq_mode
+      || bytemode == evex_half_bcst_xmmq_mode)
     {
       switch (vex.length)
        {
@@ -12705,6 +12614,8 @@ OP_XMM (int bytemode, int sizeflag ATTRIBUTE_UNUSED)
          abort ();
        }
     }
+  else if (bytemode == ymm_mode)
+    names = names_ymm;
   else if (bytemode == tmm_mode)
     {
       modrm.reg = reg;
@@ -12715,8 +12626,33 @@ OP_XMM (int bytemode, int sizeflag ATTRIBUTE_UNUSED)
        }
       names = names_tmm;
     }
-  else if (bytemode == ymm_mode)
-    names = names_ymm;
+  else if (need_vex
+          && bytemode != xmm_mode
+          && bytemode != scalar_mode)
+    {
+      switch (vex.length)
+       {
+       case 128:
+         names = names_xmm;
+         break;
+       case 256:
+         if (vex.w
+             || bytemode != vex_vsib_q_w_dq_mode)
+           names = names_ymm;
+         else
+           names = names_xmm;
+         break;
+       case 512:
+         if (vex.w
+             || bytemode != vex_vsib_q_w_dq_mode)
+           names = names_zmm;
+         else
+           names = names_ymm;
+         break;
+       default:
+         abort ();
+       }
+    }
   else
     names = names_xmm;
   oappend (names[reg]);
@@ -13419,7 +13355,6 @@ OP_VEX (int bytemode, int sizeflag ATTRIBUTE_UNUSED)
        {
        case vex_mode:
        case vex_vsib_q_w_dq_mode:
-       case vex_vsib_q_w_d_mode:
          names = names_xmm;
          break;
        case dq_mode:
@@ -13449,7 +13384,6 @@ OP_VEX (int bytemode, int sizeflag ATTRIBUTE_UNUSED)
          names = names_ymm;
          break;
        case vex_vsib_q_w_dq_mode:
-       case vex_vsib_q_w_d_mode:
          names = vex.w ? names_ymm : names_xmm;
          break;
        case mask_bd_mode:
This page took 0.035892 seconds and 4 git commands to generate.