x86: avoid string copy when swapping Vex.W controlled operands
authorJan Beulich <jbeulich@suse.com>
Mon, 13 Jun 2022 07:52:59 +0000 (09:52 +0200)
committerJan Beulich <jbeulich@suse.com>
Mon, 13 Jun 2022 07:52:59 +0000 (09:52 +0200)
Now that op_out[] is an array of pointers, there's no need anymore to
copy strings. Simply swap the pointers.

opcodes/i386-dis.c

index 602535dc18e5ea25ca301c163a1a3c66aadb15c2..d087b355103097fe8dc972a4cf4013947dd0a4b4 100644 (file)
@@ -13473,9 +13473,10 @@ OP_VexW (instr_info *ins, int bytemode, int sizeflag)
   if (ins->vex.w)
     {
       /* Swap 2nd and 3rd operands.  */
-      strcpy (ins->scratchbuf, ins->op_out[2]);
-      strcpy (ins->op_out[2], ins->op_out[1]);
-      strcpy (ins->op_out[1], ins->scratchbuf);
+      char *tmp = ins->op_out[2];
+
+      ins->op_out[2] = ins->op_out[1];
+      ins->op_out[1] = tmp;
     }
 }
 
@@ -13503,9 +13504,10 @@ OP_REG_VexI4 (instr_info *ins, int bytemode, int sizeflag ATTRIBUTE_UNUSED)
   if (ins->vex.w)
     {
       /* Swap 3rd and 4th operands.  */
-      strcpy (ins->scratchbuf, ins->op_out[3]);
-      strcpy (ins->op_out[3], ins->op_out[2]);
-      strcpy (ins->op_out[2], ins->scratchbuf);
+      char *tmp = ins->op_out[3];
+
+      ins->op_out[3] = ins->op_out[2];
+      ins->op_out[2] = tmp;
     }
 }