shithub: mc

Download patch

ref: ca205e66b097ae678a6903eeb85ff07e5c091bfa
parent: ba9f79ecd79a5d24b74f714cc8c70204d5bc26c5
author: Ori Bernstein <[email protected]>
date: Tue Dec 23 13:03:40 EST 2014

Clean up locprint(), and enable indexes.

    locprint %IDXt will print the IDXth argument of type t.

--- a/6/gengas.c
+++ b/6/gengas.c
@@ -155,7 +155,7 @@
 {
     char *p;
     int i;
-    int modeidx;
+    int idx;
 
     /* x64 has a quirk; it has no movzlq because mov zero extends. This
      * means that we need to do a movl when we really want a movzlq. Since
@@ -196,7 +196,6 @@
     }
     p = insnfmt[insn->op];
     i = 0;
-    modeidx = 0;
     for (; *p; p++) {
         if (*p !=  '%') {
             fputc(*p, fd);
@@ -205,6 +204,8 @@
 
         /* %-formating */
         p++;
+        idx = i;
+again:
         switch (*p) {
             case '\0':
                 goto done; /* skip the final p++ */
@@ -215,31 +216,19 @@
             case 'v': /* reg/mem */
             case 'u': /* reg/imm */
             case 'x': /* reg/mem/imm */
-                locprint(fd, insn->args[i], *p);
+                locprint(fd, insn->args[idx], *p);
                 i++;
                 break;
-            case 'R': /* int register */
-            case 'F': /* float register */
-            case 'M': /* memory */
-            case 'I': /* imm */
-            case 'V': /* reg/mem */
-            case 'U': /* reg/imm */
-            case 'X': /* reg/mem/imm */
-                locprint(fd, insn->args[i], *p);
-                i++;
-                break;
             case 't':
-            case 'T':
+                fputs(modenames[insn->args[idx]->mode], fd);
+                break;
             default:
                 /* the  asm description uses 1-based indexing, so that 0
                  * can be used as a sentinel. */
-                if (isdigit(*p))
-                    modeidx = strtol(p, &p, 10) - 1;
-
-                if (*p == 't')
-                    fputs(modenames[insn->args[modeidx]->mode], fd);
-                else
+                if (!isdigit(*p))
                     die("Invalid %%-specifier '%c'", *p);
+                idx = strtol(p, &p, 10) - 1;
+                goto again;
                 break;
         }
     }
--- a/6/genp9.c
+++ b/6/genp9.c
@@ -158,7 +158,7 @@
 {
     char *p;
     int i;
-    int modeidx;
+    int idx;
 
     /* x64 has a quirk; it has no movzlq because mov zero extends. This
      * means that we need to do a movl when we really want a movzlq. Since
@@ -198,8 +198,7 @@
             break;
     }
     p = insnfmt[insn->op];
-    i = 0;
-    modeidx = 0;
+    i = 0; /* NB: this is 1 based indexing */
     for (; *p; p++) {
         if (*p !=  '%') {
             fputc(*p, fd);
@@ -208,18 +207,11 @@
 
         /* %-formating */
         p++;
+        idx = i;
+again:
         switch (*p) {
             case '\0':
                 goto done; /* skip the final p++ */
-            case 'r': /* int register */
-            case 'f': /* float register */
-            case 'm': /* memory */
-            case 'i': /* imm */
-            case 'v': /* reg/mem */
-            case 'u': /* reg/imm */
-            case 'x': /* reg/mem/imm */
-                locprint(fd, insn->args[i], *p);
-                i++;
                 break;
             case 'R': /* int register */
             case 'F': /* float register */
@@ -228,21 +220,19 @@
             case 'V': /* reg/mem */
             case 'U': /* reg/imm */
             case 'X': /* reg/mem/imm */
-                locprint(fd, insn->args[i], *p);
+                locprint(fd, insn->args[idx], *p);
                 i++;
                 break;
-            case 't':
             case 'T':
+                fputs(modenames[insn->args[idx]->mode], fd);
+                break;
             default:
                 /* the  asm description uses 1-based indexing, so that 0
                  * can be used as a sentinel. */
-                if (isdigit(*p))
-                    modeidx = strtol(p, &p, 10) - 1;
-
-                if (*p == 'T')
-                    fputs(modenames[insn->args[modeidx]->mode], fd);
-                else
+                if (!isdigit(*p))
                     die("Invalid %%-specifier '%c'", *p);
+                idx = strtol(p, &p, 10) - 1;
+                goto again;
                 break;
         }
     }
--- a/6/insns.def
+++ b/6/insns.def
@@ -151,7 +151,7 @@
     Def(None))
 Insn(Icmp,      
     "\tcmp%t  %x,%r\n",             
-    "\tCMP%T  %X,%R\n",
+    "\tCMP%T  %2R,%1X\n",
     Use(.l={1,2}),
     Def(None))