Commit 3a29e876 authored by André Hentschel's avatar André Hentschel Committed by Alexandre Julliard

winedbg: Use a switch-case style implementation in thumb2_disasm_dataprocessing.

parent 2b9555fb
...@@ -1057,7 +1057,9 @@ static UINT thumb2_disasm_dataprocessing(UINT inst, ADDRESS64 *addr) ...@@ -1057,7 +1057,9 @@ static UINT thumb2_disasm_dataprocessing(UINT inst, ADDRESS64 *addr)
WORD op = (inst >> 20) & 0x1f; WORD op = (inst >> 20) & 0x1f;
WORD imm5 = ((inst >> 10) & 0x1c) + ((inst >> 6) & 0x03); WORD imm5 = ((inst >> 10) & 0x1c) + ((inst >> 6) & 0x03);
if (op == 0) switch (op)
{
case 0:
{ {
WORD offset = ((inst >> 15) & 0x0800) + ((inst >> 4) & 0x0700) + (inst & 0xff); WORD offset = ((inst >> 15) & 0x0800) + ((inst >> 4) & 0x0700) + (inst & 0xff);
if (get_nibble(inst, 4) == 15) if (get_nibble(inst, 4) == 15)
...@@ -1070,8 +1072,8 @@ static UINT thumb2_disasm_dataprocessing(UINT inst, ADDRESS64 *addr) ...@@ -1070,8 +1072,8 @@ static UINT thumb2_disasm_dataprocessing(UINT inst, ADDRESS64 *addr)
tbl_regs[get_nibble(inst, 4)], offset); tbl_regs[get_nibble(inst, 4)], offset);
return 0; return 0;
} }
case 4:
if (op == 4 || op == 12) case 12:
{ {
WORD offset = ((inst >> 15) & 0x0800) + ((inst >> 4) & 0xf000) + WORD offset = ((inst >> 15) & 0x0800) + ((inst >> 4) & 0xf000) +
((inst >> 4) & 0x0700) + (inst & 0xff); ((inst >> 4) & 0x0700) + (inst & 0xff);
...@@ -1079,8 +1081,7 @@ static UINT thumb2_disasm_dataprocessing(UINT inst, ADDRESS64 *addr) ...@@ -1079,8 +1081,7 @@ static UINT thumb2_disasm_dataprocessing(UINT inst, ADDRESS64 *addr)
offset); offset);
return 0; return 0;
} }
case 10:
if (op == 10)
{ {
int offset = ((inst >> 15) & 0x0800) + ((inst >> 4) & 0x0700) + (inst & 0xff); int offset = ((inst >> 15) & 0x0800) + ((inst >> 4) & 0x0700) + (inst & 0xff);
if (get_nibble(inst, 4) == 15) if (get_nibble(inst, 4) == 15)
...@@ -1094,8 +1095,10 @@ static UINT thumb2_disasm_dataprocessing(UINT inst, ADDRESS64 *addr) ...@@ -1094,8 +1095,10 @@ static UINT thumb2_disasm_dataprocessing(UINT inst, ADDRESS64 *addr)
tbl_regs[get_nibble(inst, 4)], offset); tbl_regs[get_nibble(inst, 4)], offset);
return 0; return 0;
} }
case 16:
if (op == 16 || op == 18 || op == 24 || op == 26) case 18:
case 24:
case 26:
{ {
BOOL sign = op < 24; BOOL sign = op < 24;
WORD sh = (inst >> 21) & 0x01; WORD sh = (inst >> 21) & 0x01;
...@@ -1110,16 +1113,15 @@ static UINT thumb2_disasm_dataprocessing(UINT inst, ADDRESS64 *addr) ...@@ -1110,16 +1113,15 @@ static UINT thumb2_disasm_dataprocessing(UINT inst, ADDRESS64 *addr)
sat, tbl_regs[get_nibble(inst, 4)]); sat, tbl_regs[get_nibble(inst, 4)]);
return 0; return 0;
} }
case 20:
if (op == 20 || op == 28) case 28:
{ {
WORD width = (inst & 0x1f) + 1; WORD width = (inst & 0x1f) + 1;
dbg_printf("\n\t%s\t%s, %s, #%u, #%u", op == 28 ? "ubfx" : "sbfx", dbg_printf("\n\t%s\t%s, %s, #%u, #%u", op == 28 ? "ubfx" : "sbfx",
tbl_regs[get_nibble(inst, 2)], tbl_regs[get_nibble(inst, 4)], imm5, width); tbl_regs[get_nibble(inst, 2)], tbl_regs[get_nibble(inst, 4)], imm5, width);
return 0; return 0;
} }
case 22:
if (op == 22)
{ {
WORD msb = (inst & 0x1f) + 1 - imm5; WORD msb = (inst & 0x1f) + 1 - imm5;
if (get_nibble(inst, 4) == 15) if (get_nibble(inst, 4) == 15)
...@@ -1129,8 +1131,9 @@ static UINT thumb2_disasm_dataprocessing(UINT inst, ADDRESS64 *addr) ...@@ -1129,8 +1131,9 @@ static UINT thumb2_disasm_dataprocessing(UINT inst, ADDRESS64 *addr)
tbl_regs[get_nibble(inst, 4)], imm5, msb); tbl_regs[get_nibble(inst, 4)], imm5, msb);
return 0; return 0;
} }
default:
return inst; return inst;
}
} }
static UINT thumb2_disasm_dataprocessingmod(UINT inst, ADDRESS64 *addr) static UINT thumb2_disasm_dataprocessingmod(UINT inst, ADDRESS64 *addr)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment