summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJin Kyu Song <jin.kyu.song@intel.com>2013-11-19 18:44:13 -0800
committerJin Kyu Song <jin.kyu.song@intel.com>2013-11-20 11:29:42 -0800
commit28d5bf811b02b4ffa61b4100df11bc0872ea84bf (patch)
tree1c630bac1476e2d5d0a52060b6ae0a2877d7571a
parent5f80dace3a2b15ecc07d07d8ce37bac6cb5f1d4c (diff)
downloadnasm-28d5bf811b02b4ffa61b4100df11bc0872ea84bf.tar.gz
disasm: Add suport for bnd registers
MPX uses a new bnd registers and a new mib syntax. Signed-off-by: Jin Kyu Song <jin.kyu.song@intel.com>
-rw-r--r--disasm.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/disasm.c b/disasm.c
index 50a49c54..72a0261b 100644
--- a/disasm.c
+++ b/disasm.c
@@ -192,6 +192,8 @@ static enum reg_enum whichreg(opflags_t regflags, int regval, int rex)
return nasm_rd_zmmreg[regval];
if (!(OPMASKREG & ~regflags))
return nasm_rd_opmaskreg[regval];
+ if (!(BNDREG & ~regflags))
+ return nasm_rd_bndreg[regval];
return 0;
}
@@ -614,6 +616,11 @@ static int matches(const struct itemplate *t, uint8_t *data,
break;
}
+ case4(014):
+ /* this is an separate index reg position of MIB operand (ICC) */
+ /* Disassembler uses NASM's split EA form only */
+ break;
+
case4(0274):
opx->offset = (int8_t)*data++;
opx->segment |= SEG_SIGNED;