diff options
author | Jan Beulich <jbeulich@suse.com> | 2021-07-22 13:08:05 +0200 |
---|---|---|
committer | Jan Beulich <jbeulich@suse.com> | 2021-07-22 13:08:05 +0200 |
commit | b0556968af05310748d7a1286b8d7639de67831e (patch) | |
tree | 2db21e8f9eaee82c7026a39f64a0ac47934d7f9c | |
parent | 605228fcaf91a86b5ae898415374a9382c85f76f (diff) | |
download | gdb-b0556968af05310748d7a1286b8d7639de67831e.zip gdb-b0556968af05310748d7a1286b8d7639de67831e.tar.gz gdb-b0556968af05310748d7a1286b8d7639de67831e.tar.bz2 |
x86: fold duplicate vector register printing code
The bulk of OP_XMM() can be easily reused also for OP_EX(). Break the
shared logic out of the function, and invoke the new helper from both
places.
-rw-r--r-- | opcodes/i386-dis.c | 107 |
1 files changed, 33 insertions, 74 deletions
diff --git a/opcodes/i386-dis.c b/opcodes/i386-dis.c index 20bf9b2..e750c94 100644 --- a/opcodes/i386-dis.c +++ b/opcodes/i386-dis.c @@ -12530,20 +12530,10 @@ OP_MMX (int bytemode ATTRIBUTE_UNUSED, int sizeflag ATTRIBUTE_UNUSED) } static void -OP_XMM (int bytemode, int sizeflag ATTRIBUTE_UNUSED) +print_vector_reg (unsigned int reg, int bytemode) { - int reg = modrm.reg; const char **names; - USED_REX (REX_R); - if (rex & REX_R) - reg += 8; - if (vex.evex) - { - if (!vex.r) - reg += 16; - } - if (bytemode == xmmq_mode || bytemode == evex_half_bcst_xmmq_mode) { @@ -12564,7 +12554,6 @@ OP_XMM (int bytemode, int sizeflag ATTRIBUTE_UNUSED) names = names_ymm; else if (bytemode == tmm_mode) { - modrm.reg = reg; if (reg >= 8) { oappend ("(bad)"); @@ -12574,7 +12563,14 @@ OP_XMM (int bytemode, int sizeflag ATTRIBUTE_UNUSED) } else if (need_vex && bytemode != xmm_mode - && bytemode != scalar_mode) + && bytemode != scalar_mode + && bytemode != xmmdw_mode + && bytemode != xmmqd_mode + && bytemode != xmm_mb_mode + && bytemode != xmm_mw_mode + && bytemode != xmm_md_mode + && bytemode != xmm_mq_mode + && bytemode != vex_scalar_w_dq_mode) { switch (vex.length) { @@ -12605,6 +12601,26 @@ OP_XMM (int bytemode, int sizeflag ATTRIBUTE_UNUSED) } static void +OP_XMM (int bytemode, int sizeflag ATTRIBUTE_UNUSED) +{ + unsigned int reg = modrm.reg; + + USED_REX (REX_R); + if (rex & REX_R) + reg += 8; + if (vex.evex) + { + if (!vex.r) + reg += 16; + } + + if (bytemode == tmm_mode) + modrm.reg = reg; + + print_vector_reg (reg, bytemode); +} + +static void OP_EM (int bytemode, int sizeflag) { int reg; @@ -12679,7 +12695,6 @@ static void OP_EX (int bytemode, int sizeflag) { int reg; - const char **names; /* Skip mod/rm byte. */ MODRM_CHECK; @@ -12708,66 +12723,10 @@ OP_EX (int bytemode, int sizeflag) || bytemode == q_swap_mode)) swap_operand (); - if (need_vex - && bytemode != xmm_mode - && bytemode != xmmdw_mode - && bytemode != xmmqd_mode - && bytemode != xmm_mb_mode - && bytemode != xmm_mw_mode - && bytemode != xmm_md_mode - && bytemode != xmm_mq_mode - && bytemode != xmmq_mode - && bytemode != evex_half_bcst_xmmq_mode - && bytemode != ymm_mode - && bytemode != tmm_mode - && bytemode != vex_scalar_w_dq_mode) - { - switch (vex.length) - { - case 128: - names = names_xmm; - break; - case 256: - names = names_ymm; - break; - case 512: - names = names_zmm; - break; - default: - abort (); - } - } - else if (bytemode == xmmq_mode - || bytemode == evex_half_bcst_xmmq_mode) - { - switch (vex.length) - { - case 128: - case 256: - names = names_xmm; - break; - case 512: - names = names_ymm; - break; - default: - abort (); - } - } - else if (bytemode == tmm_mode) - { - modrm.rm = reg; - if (reg >= 8) - { - oappend ("(bad)"); - return; - } - names = names_tmm; - } - else if (bytemode == ymm_mode) - names = names_ymm; - else - names = names_xmm; - oappend (names[reg]); + if (bytemode == tmm_mode) + modrm.rm = reg; + + print_vector_reg (reg, bytemode); } static void |