aboutsummaryrefslogtreecommitdiff
path: root/opcodes
diff options
context:
space:
mode:
authorJan Beulich <jbeulich@suse.com>2020-07-14 10:41:30 +0200
committerJan Beulich <jbeulich@suse.com>2020-07-14 10:41:30 +0200
commitbb5b3501b3d639bd4f7da4b3be791fb059c8a835 (patch)
treeccbb34f30c6e0746db61735c7835ff584c8aaac9 /opcodes
parent025a39a7c26e9f19985a392797c9499923a555d7 (diff)
downloadgdb-bb5b3501b3d639bd4f7da4b3be791fb059c8a835.zip
gdb-bb5b3501b3d639bd4f7da4b3be791fb059c8a835.tar.gz
gdb-bb5b3501b3d639bd4f7da4b3be791fb059c8a835.tar.bz2
x86: also use %BW / %DQ for kshift*
Diffstat (limited to 'opcodes')
-rw-r--r--opcodes/ChangeLog18
-rw-r--r--opcodes/i386-dis.c82
2 files changed, 35 insertions, 65 deletions
diff --git a/opcodes/ChangeLog b/opcodes/ChangeLog
index 6d43129..b6d52c4 100644
--- a/opcodes/ChangeLog
+++ b/opcodes/ChangeLog
@@ -1,5 +1,23 @@
2020-07-14 Jan Beulich <jbeulich@suse.com>
+ * i386-dis.c (MOD_VEX_0F3A30_L_0_W_0, MOD_VEX_0F3A30_L_0_W_1,
+ MOD_VEX_0F3A31_L_0_W_0, MOD_VEX_0F3A31_L_0_W_1,
+ MOD_VEX_0F3A32_L_0_W_0, MOD_VEX_0F3A32_L_0_W_1,
+ MOD_VEX_0F3A33_L_0_W_0, MOD_VEX_0F3A33_L_0_W_1): Replace by ...
+ (MOD_VEX_0F3A30_L_0, MOD_VEX_0F3A31_L_0,
+ MOD_VEX_0F3A32_L_0, MOD_VEX_0F3A33_L_0): ... these.
+ (VEX_W_0F3A30_L_0, VEX_W_0F3A31_L_0, VEX_W_0F3A32_L_0,
+ VEX_W_0F3A33_L_0): Delete.
+ (dis386): Adjust "BW" description.
+ (vex_len_table): Refer to mod_table[] for opcodes 0F3A30,
+ 0F3A31, 0F3A32, and 0F3A33.
+ (vex_w_table): Delete opcode 0F3A30, 0F3A31, 0F3A32, and 0F3A33
+ entries.
+ (mod_table): Replace opcode 0F3A30, 0F3A31, 0F3A32, and 0F3A33
+ entries.
+
+2020-07-14 Jan Beulich <jbeulich@suse.com>
+
* i386-dis.c (PREFIX_0F6C, PREFIX_0F6D, PREFIX_0F73_REG_3,
PREFIX_0F73_REG_7, PREFIX_0F3810, PREFIX_0F3814, PREFIX_0F3815,
PREFIX_0F3817, PREFIX_0F3820, PREFIX_0F3821, PREFIX_0F3822,
diff --git a/opcodes/i386-dis.c b/opcodes/i386-dis.c
index 583d1d0..12fd32a 100644
--- a/opcodes/i386-dis.c
+++ b/opcodes/i386-dis.c
@@ -894,14 +894,10 @@ enum
MOD_VEX_0F385A,
MOD_VEX_0F388C,
MOD_VEX_0F388E,
- MOD_VEX_0F3A30_L_0_W_0,
- MOD_VEX_0F3A30_L_0_W_1,
- MOD_VEX_0F3A31_L_0_W_0,
- MOD_VEX_0F3A31_L_0_W_1,
- MOD_VEX_0F3A32_L_0_W_0,
- MOD_VEX_0F3A32_L_0_W_1,
- MOD_VEX_0F3A33_L_0_W_0,
- MOD_VEX_0F3A33_L_0_W_1,
+ MOD_VEX_0F3A30_L_0,
+ MOD_VEX_0F3A31_L_0,
+ MOD_VEX_0F3A32_L_0,
+ MOD_VEX_0F3A33_L_0,
MOD_VEX_0FXOP_09_12,
@@ -1517,10 +1513,6 @@ enum
VEX_W_0F3A18_L_1,
VEX_W_0F3A19_L_1,
VEX_W_0F3A1D,
- VEX_W_0F3A30_L_0,
- VEX_W_0F3A31_L_0,
- VEX_W_0F3A32_L_0,
- VEX_W_0F3A33_L_0,
VEX_W_0F3A38_L_1,
VEX_W_0F3A39_L_1,
VEX_W_0F3A46_L_1,
@@ -1799,7 +1791,7 @@ struct dis386 {
"LS" => print "abs" in 64bit mode and behave as 'S' otherwise
"LV" => print "abs" for 64bit operand and behave as 'S' otherwise
"DQ" => print 'd' or 'q' depending on the VEX.W bit
- "BW" => print 'b' or 'w' depending on the EVEX.W bit
+ "BW" => print 'b' or 'w' depending on the VEX.W bit
"LP" => print 'w' or 'l' ('d' in Intel mode) if instruction has
an operand size prefix, or suffix_always is true. print
'q' if rex prefix is present.
@@ -7079,22 +7071,22 @@ static const struct dis386 vex_len_table[][2] = {
/* VEX_LEN_0F3A30 */
{
- { VEX_W_TABLE (VEX_W_0F3A30_L_0) },
+ { MOD_TABLE (MOD_VEX_0F3A30_L_0) },
},
/* VEX_LEN_0F3A31 */
{
- { VEX_W_TABLE (VEX_W_0F3A31_L_0) },
+ { MOD_TABLE (MOD_VEX_0F3A31_L_0) },
},
/* VEX_LEN_0F3A32 */
{
- { VEX_W_TABLE (VEX_W_0F3A32_L_0) },
+ { MOD_TABLE (MOD_VEX_0F3A32_L_0) },
},
/* VEX_LEN_0F3A33 */
{
- { VEX_W_TABLE (VEX_W_0F3A33_L_0) },
+ { MOD_TABLE (MOD_VEX_0F3A33_L_0) },
},
/* VEX_LEN_0F3A38 */
@@ -7746,26 +7738,6 @@ static const struct dis386 vex_w_table[][2] = {
{ "vcvtps2ph", { EXxmmq, XM, EXxEVexS, Ib }, PREFIX_DATA },
},
{
- /* VEX_W_0F3A30_L_0 */
- { MOD_TABLE (MOD_VEX_0F3A30_L_0_W_0) },
- { MOD_TABLE (MOD_VEX_0F3A30_L_0_W_1) },
- },
- {
- /* VEX_W_0F3A31_L_0 */
- { MOD_TABLE (MOD_VEX_0F3A31_L_0_W_0) },
- { MOD_TABLE (MOD_VEX_0F3A31_L_0_W_1) },
- },
- {
- /* VEX_W_0F3A32_L_0 */
- { MOD_TABLE (MOD_VEX_0F3A32_L_0_W_0) },
- { MOD_TABLE (MOD_VEX_0F3A32_L_0_W_1) },
- },
- {
- /* VEX_W_0F3A33_L_0 */
- { MOD_TABLE (MOD_VEX_0F3A33_L_0_W_0) },
- { MOD_TABLE (MOD_VEX_0F3A33_L_0_W_1) },
- },
- {
/* VEX_W_0F3A38_L_1 */
{ "vinserti128", { XM, Vex, EXxmm, Ib }, PREFIX_DATA },
},
@@ -8765,44 +8737,24 @@ static const struct dis386 mod_table[][2] = {
{ "vpmaskmov%DQ", { Mx, Vex, XM }, PREFIX_DATA },
},
{
- /* MOD_VEX_0F3A30_L_0_W_0 */
- { Bad_Opcode },
- { "kshiftrb", { MaskG, MaskR, Ib }, PREFIX_DATA },
- },
- {
- /* MOD_VEX_0F3A30_L_0_W_1 */
- { Bad_Opcode },
- { "kshiftrw", { MaskG, MaskR, Ib }, PREFIX_DATA },
- },
- {
- /* MOD_VEX_0F3A31_L_0_W_0 */
- { Bad_Opcode },
- { "kshiftrd", { MaskG, MaskR, Ib }, PREFIX_DATA },
- },
- {
- /* MOD_VEX_0F3A31_L_0_W_1 */
- { Bad_Opcode },
- { "kshiftrq", { MaskG, MaskR, Ib }, PREFIX_DATA },
- },
- {
- /* MOD_VEX_0F3A32_L_0_W_0 */
+ /* MOD_VEX_0F3A30_L_0 */
{ Bad_Opcode },
- { "kshiftlb", { MaskG, MaskR, Ib }, PREFIX_DATA },
+ { "kshiftr%BW", { MaskG, MaskR, Ib }, PREFIX_DATA },
},
{
- /* MOD_VEX_0F3A32_L_0_W_1 */
+ /* MOD_VEX_0F3A31_L_0 */
{ Bad_Opcode },
- { "kshiftlw", { MaskG, MaskR, Ib }, PREFIX_DATA },
+ { "kshiftr%DQ", { MaskG, MaskR, Ib }, PREFIX_DATA },
},
{
- /* MOD_VEX_0F3A33_L_0_W_0 */
+ /* MOD_VEX_0F3A32_L_0 */
{ Bad_Opcode },
- { "kshiftld", { MaskG, MaskR, Ib }, PREFIX_DATA },
+ { "kshiftl%BW", { MaskG, MaskR, Ib }, PREFIX_DATA },
},
{
- /* MOD_VEX_0F3A33_L_0_W_1 */
+ /* MOD_VEX_0F3A33_L_0 */
{ Bad_Opcode },
- { "kshiftlq", { MaskG, MaskR, Ib }, PREFIX_DATA },
+ { "kshiftl%DQ", { MaskG, MaskR, Ib }, PREFIX_DATA },
},
{
/* MOD_VEX_0FXOP_09_12 */