From: Jan Beulich Date: Thu, 11 Mar 2021 15:21:48 +0000 (+0100) Subject: x86: re-order logic in OP_XMM() X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=fd1fd0618645c5d4ff4279433360e3a7fd779fba;p=binutils-gdb.git x86: re-order logic in OP_XMM() Instead of excluding an increasing number of modes in the initial if(), check the special modes first. --- diff --git a/opcodes/ChangeLog b/opcodes/ChangeLog index e31a93f7de9..60a9c687250 100644 --- a/opcodes/ChangeLog +++ b/opcodes/ChangeLog @@ -1,3 +1,7 @@ +2021-03-11 Jan Beulich + + * i386-dis.c (OP_XMM): Re-order checks. + 2021-03-11 Jan Beulich * i386-dis.c (putop): Drop need_vex check when also checking diff --git a/opcodes/i386-dis.c b/opcodes/i386-dis.c index 10dbe7fe183..2985e8d4417 100644 --- a/opcodes/i386-dis.c +++ b/opcodes/i386-dis.c @@ -12598,39 +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) - 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 if (bytemode == xmmq_mode - || bytemode == evex_half_bcst_xmmq_mode) + if (bytemode == xmmq_mode + || bytemode == evex_half_bcst_xmmq_mode) { switch (vex.length) { @@ -12645,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; @@ -12655,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]);