x86: minor improvements to optimize_imm()
authorJan Beulich <jbeulich@suse.com>
Fri, 7 May 2021 10:02:07 +0000 (12:02 +0200)
committerJan Beulich <jbeulich@suse.com>
Fri, 7 May 2021 10:02:07 +0000 (12:02 +0200)
- Drop a pointless & where just before it was checked that the
  respective bits are clear already anyway.
- Avoid a not really necessary operand_type_set() and a redundant
  operand_type_or() / operand_type_and() pair.

gas/ChangeLog
gas/config/tc-i386.c

index 790951ad9327fbfe81b4671a6faa1d6a05f36b96..ad82f9b3c75c28daceeb38d574365f19d169f4c4 100644 (file)
@@ -1,3 +1,8 @@
+2021-05-07  Jan Beulich  <jbeulich@suse.com>
+
+       * config/tc-i386.c (optimize_imm): Drop redundant masking.
+       Re-arrange operand type accumulation.
+
 2021-05-06  Stafford Horne  <shorne@gmail.com>
 
        PR 21464
index 5d5897fdb2b434363a2f6a9abac106a70a845b61..c09d63f5e210fe96e7c45a01807a6a9033d1f90a 100644 (file)
@@ -5791,8 +5791,8 @@ optimize_imm (void)
            if ((i.types[op].bitfield.imm16)
                && (i.op[op].imms->X_add_number & ~(offsetT) 0xffff) == 0)
              {
-               i.op[op].imms->X_add_number =
-                 (((i.op[op].imms->X_add_number & 0xffff) ^ 0x8000) - 0x8000);
+               i.op[op].imms->X_add_number = ((i.op[op].imms->X_add_number
+                                               ^ 0x8000) - 0x8000);
              }
 #ifdef BFD64
            /* Store 32-bit immediate in 64-bit for 64-bit BFD.  */
@@ -5826,17 +5826,15 @@ optimize_imm (void)
               than those matching the insn suffix.  */
            {
              i386_operand_type mask, allowed;
-             const insn_template *t;
+             const insn_template *t = current_templates->start;
 
              operand_type_set (&mask, 0);
-             operand_type_set (&allowed, 0);
+             allowed = t->operand_types[op];
 
-             for (t = current_templates->start;
-                  t < current_templates->end;
-                  ++t)
+             while (++t < current_templates->end)
                {
-                 allowed = operand_type_or (allowed, t->operand_types[op]);
                  allowed = operand_type_and (allowed, anyimm);
+                 allowed = operand_type_or (allowed, t->operand_types[op]);
                }
              switch (guess_suffix)
                {