=?UTF-8?Q?Andr=C3=A9=20Hentschel=20?=: winedbg: Add multiplication operators to ARM disassembler.

Alexandre Julliard julliard at winehq.org
Mon Jul 9 14:56:37 CDT 2012


Module: wine
Branch: master
Commit: 498614dda69f04f688de35e1b93c6ab844812d47
URL:    http://source.winehq.org/git/wine.git/?a=commit;h=498614dda69f04f688de35e1b93c6ab844812d47

Author: André Hentschel <nerv at dawncrow.de>
Date:   Sat Jul  7 15:11:06 2012 +0200

winedbg: Add multiplication operators to ARM disassembler.

---

 programs/winedbg/be_arm.c |   31 +++++++++++++++++++++++++++++++
 1 files changed, 31 insertions(+), 0 deletions(-)

diff --git a/programs/winedbg/be_arm.c b/programs/winedbg/be_arm.c
index bc19c98..3beb60a 100644
--- a/programs/winedbg/be_arm.c
+++ b/programs/winedbg/be_arm.c
@@ -127,6 +127,35 @@ static UINT arm_disasm_branch(UINT inst, ADDRESS64 *addr)
     return 0;
 }
 
+static UINT arm_disasm_mul(UINT inst, ADDRESS64 *addr)
+{
+    short accu = (inst >> 21) & 0x01;
+    short condcodes = (inst >> 20) & 0x01;
+
+    if (accu)
+        dbg_printf("\n\tmla%s%s\t%s, %s, %s, %s", get_cond(inst), condcodes ? "s" : "",
+                   tbl_regs[get_nibble(inst, 4)], tbl_regs[get_nibble(inst, 0)],
+                   tbl_regs[get_nibble(inst, 2)], tbl_regs[get_nibble(inst, 3)]);
+    else
+        dbg_printf("\n\tmul%s%s\t%s, %s, %s", get_cond(inst), condcodes ? "s" : "",
+                   tbl_regs[get_nibble(inst, 4)], tbl_regs[get_nibble(inst, 0)],
+                   tbl_regs[get_nibble(inst, 2)]);
+    return 0;
+}
+
+static UINT arm_disasm_longmul(UINT inst, ADDRESS64 *addr)
+{
+    short sign = (inst >> 22) & 0x01;
+    short accu = (inst >> 21) & 0x01;
+    short condcodes = (inst >> 20) & 0x01;
+
+    dbg_printf("\n\t%s%s%s%s\t%s, %s, %s, %s", sign ? "s" : "u", accu ? "mlal" : "mull",
+               get_cond(inst), condcodes ? "s" : "",
+               tbl_regs[get_nibble(inst, 3)], tbl_regs[get_nibble(inst, 4)],
+               tbl_regs[get_nibble(inst, 0)], tbl_regs[get_nibble(inst, 2)]);
+    return 0;
+}
+
 static UINT arm_disasm_branchreg(UINT inst, ADDRESS64 *addr)
 {
     dbg_printf("\n\tb%s\t%s", get_cond(inst), tbl_regs[get_nibble(inst, 0)]);
@@ -696,6 +725,8 @@ struct inst_arm
 
 static const struct inst_arm tbl_arm[] = {
     { 0x0e000000, 0x0a000000, arm_disasm_branch },
+    { 0x0fc000f0, 0x00000090, arm_disasm_mul },
+    { 0x0f8000f0, 0x00800090, arm_disasm_longmul },
     { 0x0e000090, 0x00000090, arm_disasm_halfwordtrans },
     { 0x0ffffff0, 0x012fff00, arm_disasm_branchreg },
     { 0x0ffffff0, 0x012fff10, arm_disasm_branchxchg },




More information about the wine-cvs mailing list