diff --git a/src/emu/cpu/arcompact/arcompact.h b/src/emu/cpu/arcompact/arcompact.h index bedef23f5d5..573ff27c629 100644 --- a/src/emu/cpu/arcompact/arcompact.h +++ b/src/emu/cpu/arcompact/arcompact.h @@ -36,7 +36,7 @@ protected: // device_disasm_interface overrides virtual UINT32 disasm_min_opcode_bytes() const { return 2; } - virtual UINT32 disasm_max_opcode_bytes() const { return 4; } + virtual UINT32 disasm_max_opcode_bytes() const { return 8; } virtual offs_t disasm_disassemble(char *buffer, offs_t pc, const UINT8 *oprom, const UINT8 *opram, UINT32 options); private: diff --git a/src/emu/cpu/arcompact/arcompactdasm.c b/src/emu/cpu/arcompact/arcompactdasm.c index 148a91690e1..4488939fbd5 100644 --- a/src/emu/cpu/arcompact/arcompactdasm.c +++ b/src/emu/cpu/arcompact/arcompactdasm.c @@ -26,6 +26,9 @@ static void ATTR_PRINTF(1,2) print(const char *fmt, ...) #define DASM_OPS_16 char *output, offs_t pc, UINT16 op, const UINT8* oprom #define DASM_OPS_32 char *output, offs_t pc, UINT32 op, const UINT8* oprom +#define DASM_PARAMS output, pc, op, oprom + +#define LIMM_REG 62 int arcompact_handle04_00_dasm(DASM_OPS_32); int arcompact_handle04_01_dasm(DASM_OPS_32); @@ -157,6 +160,76 @@ int arcompact_handle04_2f_3d_dasm(DASM_OPS_32); int arcompact_handle04_2f_3e_dasm(DASM_OPS_32); int arcompact_handle04_2f_3f_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_00_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_01_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_02_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_03_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_04_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_05_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_06_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_07_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_08_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_09_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_0a_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_0b_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_0c_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_0d_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_0e_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_0f_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_10_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_11_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_12_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_13_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_14_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_15_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_16_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_17_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_18_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_19_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_1a_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_1b_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_1c_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_1d_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_1e_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_1f_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_20_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_21_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_22_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_23_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_24_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_25_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_26_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_27_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_28_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_29_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_2a_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_2b_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_2c_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_2d_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_2e_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_2f_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_30_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_31_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_32_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_33_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_34_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_35_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_36_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_37_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_38_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_39_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_3a_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_3b_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_3c_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_3d_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_3e_dasm(DASM_OPS_32); +int arcompact_handle04_2f_3f_3f_dasm(DASM_OPS_32); + +int arcompact_handle0e_00_dasm(DASM_OPS_16); +int arcompact_handle0e_01_dasm(DASM_OPS_16); +int arcompact_handle0e_02_dasm(DASM_OPS_16); +int arcompact_handle0e_03_dasm(DASM_OPS_16); + int arcompact_handle18_00_dasm(DASM_OPS_16); int arcompact_handle18_01_dasm(DASM_OPS_16); int arcompact_handle18_02_dasm(DASM_OPS_16); @@ -508,70 +581,70 @@ int arcompact_handle04_dasm(DASM_OPS_32) switch (subinstr) { - case 0x00: size = arcompact_handle04_00_dasm(output, pc, op, oprom); break; // ADD - case 0x01: size = arcompact_handle04_01_dasm(output, pc, op, oprom); break; // ADC - case 0x02: size = arcompact_handle04_02_dasm(output, pc, op, oprom); break; // SUB - case 0x03: size = arcompact_handle04_03_dasm(output, pc, op, oprom); break; // SBC - case 0x04: size = arcompact_handle04_04_dasm(output, pc, op, oprom); break; // AND - case 0x05: size = arcompact_handle04_05_dasm(output, pc, op, oprom); break; // OR - case 0x06: size = arcompact_handle04_06_dasm(output, pc, op, oprom); break; // BIC - case 0x07: size = arcompact_handle04_07_dasm(output, pc, op, oprom); break; // XOR - case 0x08: size = arcompact_handle04_08_dasm(output, pc, op, oprom); break; // MAX - case 0x09: size = arcompact_handle04_09_dasm(output, pc, op, oprom); break; // MIN - case 0x0a: size = arcompact_handle04_0a_dasm(output, pc, op, oprom); break; // MOV - case 0x0b: size = arcompact_handle04_0b_dasm(output, pc, op, oprom); break; // TST - case 0x0c: size = arcompact_handle04_0c_dasm(output, pc, op, oprom); break; // CMP - case 0x0d: size = arcompact_handle04_0d_dasm(output, pc, op, oprom); break; // RCMP - case 0x0e: size = arcompact_handle04_0e_dasm(output, pc, op, oprom); break; // RSUB - case 0x0f: size = arcompact_handle04_0f_dasm(output, pc, op, oprom); break; // BSET - case 0x10: size = arcompact_handle04_10_dasm(output, pc, op, oprom); break; // BCLR - case 0x11: size = arcompact_handle04_11_dasm(output, pc, op, oprom); break; // BTST - case 0x12: size = arcompact_handle04_12_dasm(output, pc, op, oprom); break; // BXOR - case 0x13: size = arcompact_handle04_13_dasm(output, pc, op, oprom); break; // BMSK - case 0x14: size = arcompact_handle04_14_dasm(output, pc, op, oprom); break; // ADD1 - case 0x15: size = arcompact_handle04_15_dasm(output, pc, op, oprom); break; // ADD2 - case 0x16: size = arcompact_handle04_16_dasm(output, pc, op, oprom); break; // ADD3 - case 0x17: size = arcompact_handle04_17_dasm(output, pc, op, oprom); break; // SUB1 - case 0x18: size = arcompact_handle04_18_dasm(output, pc, op, oprom); break; // SUB2 - case 0x19: size = arcompact_handle04_19_dasm(output, pc, op, oprom); break; // SUB3 - case 0x1a: size = arcompact_handle04_1a_dasm(output, pc, op, oprom); break; // MPY * - case 0x1b: size = arcompact_handle04_1b_dasm(output, pc, op, oprom); break; // MPYH * - case 0x1c: size = arcompact_handle04_1c_dasm(output, pc, op, oprom); break; // MPYHU * - case 0x1d: size = arcompact_handle04_1d_dasm(output, pc, op, oprom); break; // MPYU * - case 0x1e: size = arcompact_handle04_1e_dasm(output, pc, op, oprom); break; // illegal - case 0x1f: size = arcompact_handle04_1f_dasm(output, pc, op, oprom); break; // illegal - case 0x20: size = arcompact_handle04_20_dasm(output, pc, op, oprom); break; // Jcc - case 0x21: size = arcompact_handle04_21_dasm(output, pc, op, oprom); break; // Jcc.D - case 0x22: size = arcompact_handle04_22_dasm(output, pc, op, oprom); break; // JLcc - case 0x23: size = arcompact_handle04_23_dasm(output, pc, op, oprom); break; // JLcc.D - case 0x24: size = arcompact_handle04_24_dasm(output, pc, op, oprom); break; // illegal - case 0x25: size = arcompact_handle04_25_dasm(output, pc, op, oprom); break; // illegal - case 0x26: size = arcompact_handle04_26_dasm(output, pc, op, oprom); break; // illegal - case 0x27: size = arcompact_handle04_27_dasm(output, pc, op, oprom); break; // illegal - case 0x28: size = arcompact_handle04_28_dasm(output, pc, op, oprom); break; // LPcc - case 0x29: size = arcompact_handle04_29_dasm(output, pc, op, oprom); break; // FLAG - case 0x2a: size = arcompact_handle04_2a_dasm(output, pc, op, oprom); break; // LR - case 0x2b: size = arcompact_handle04_2b_dasm(output, pc, op, oprom); break; // SR - case 0x2c: size = arcompact_handle04_2c_dasm(output, pc, op, oprom); break; // illegal - case 0x2d: size = arcompact_handle04_2d_dasm(output, pc, op, oprom); break; // illegal - case 0x2e: size = arcompact_handle04_2e_dasm(output, pc, op, oprom); break; // illegal - case 0x2f: size = arcompact_handle04_2f_dasm(output, pc, op, oprom); break; // Sub Opcode - case 0x30: size = arcompact_handle04_30_dasm(output, pc, op, oprom); break; // LD r-r - case 0x31: size = arcompact_handle04_31_dasm(output, pc, op, oprom); break; // LD r-r - case 0x32: size = arcompact_handle04_32_dasm(output, pc, op, oprom); break; // LD r-r - case 0x33: size = arcompact_handle04_33_dasm(output, pc, op, oprom); break; // LD r-r - case 0x34: size = arcompact_handle04_34_dasm(output, pc, op, oprom); break; // LD r-r - case 0x35: size = arcompact_handle04_35_dasm(output, pc, op, oprom); break; // LD r-r - case 0x36: size = arcompact_handle04_36_dasm(output, pc, op, oprom); break; // LD r-r - case 0x37: size = arcompact_handle04_37_dasm(output, pc, op, oprom); break; // LD r-r - case 0x38: size = arcompact_handle04_38_dasm(output, pc, op, oprom); break; // illegal - case 0x39: size = arcompact_handle04_39_dasm(output, pc, op, oprom); break; // illegal - case 0x3a: size = arcompact_handle04_3a_dasm(output, pc, op, oprom); break; // illegal - case 0x3b: size = arcompact_handle04_3b_dasm(output, pc, op, oprom); break; // illegal - case 0x3c: size = arcompact_handle04_3c_dasm(output, pc, op, oprom); break; // illegal - case 0x3d: size = arcompact_handle04_3d_dasm(output, pc, op, oprom); break; // illegal - case 0x3e: size = arcompact_handle04_3e_dasm(output, pc, op, oprom); break; // illegal - case 0x3f: size = arcompact_handle04_3f_dasm(output, pc, op, oprom); break; // illegal + case 0x00: size = arcompact_handle04_00_dasm(DASM_PARAMS); break; // ADD + case 0x01: size = arcompact_handle04_01_dasm(DASM_PARAMS); break; // ADC + case 0x02: size = arcompact_handle04_02_dasm(DASM_PARAMS); break; // SUB + case 0x03: size = arcompact_handle04_03_dasm(DASM_PARAMS); break; // SBC + case 0x04: size = arcompact_handle04_04_dasm(DASM_PARAMS); break; // AND + case 0x05: size = arcompact_handle04_05_dasm(DASM_PARAMS); break; // OR + case 0x06: size = arcompact_handle04_06_dasm(DASM_PARAMS); break; // BIC + case 0x07: size = arcompact_handle04_07_dasm(DASM_PARAMS); break; // XOR + case 0x08: size = arcompact_handle04_08_dasm(DASM_PARAMS); break; // MAX + case 0x09: size = arcompact_handle04_09_dasm(DASM_PARAMS); break; // MIN + case 0x0a: size = arcompact_handle04_0a_dasm(DASM_PARAMS); break; // MOV + case 0x0b: size = arcompact_handle04_0b_dasm(DASM_PARAMS); break; // TST + case 0x0c: size = arcompact_handle04_0c_dasm(DASM_PARAMS); break; // CMP + case 0x0d: size = arcompact_handle04_0d_dasm(DASM_PARAMS); break; // RCMP + case 0x0e: size = arcompact_handle04_0e_dasm(DASM_PARAMS); break; // RSUB + case 0x0f: size = arcompact_handle04_0f_dasm(DASM_PARAMS); break; // BSET + case 0x10: size = arcompact_handle04_10_dasm(DASM_PARAMS); break; // BCLR + case 0x11: size = arcompact_handle04_11_dasm(DASM_PARAMS); break; // BTST + case 0x12: size = arcompact_handle04_12_dasm(DASM_PARAMS); break; // BXOR + case 0x13: size = arcompact_handle04_13_dasm(DASM_PARAMS); break; // BMSK + case 0x14: size = arcompact_handle04_14_dasm(DASM_PARAMS); break; // ADD1 + case 0x15: size = arcompact_handle04_15_dasm(DASM_PARAMS); break; // ADD2 + case 0x16: size = arcompact_handle04_16_dasm(DASM_PARAMS); break; // ADD3 + case 0x17: size = arcompact_handle04_17_dasm(DASM_PARAMS); break; // SUB1 + case 0x18: size = arcompact_handle04_18_dasm(DASM_PARAMS); break; // SUB2 + case 0x19: size = arcompact_handle04_19_dasm(DASM_PARAMS); break; // SUB3 + case 0x1a: size = arcompact_handle04_1a_dasm(DASM_PARAMS); break; // MPY * + case 0x1b: size = arcompact_handle04_1b_dasm(DASM_PARAMS); break; // MPYH * + case 0x1c: size = arcompact_handle04_1c_dasm(DASM_PARAMS); break; // MPYHU * + case 0x1d: size = arcompact_handle04_1d_dasm(DASM_PARAMS); break; // MPYU * + case 0x1e: size = arcompact_handle04_1e_dasm(DASM_PARAMS); break; // illegal + case 0x1f: size = arcompact_handle04_1f_dasm(DASM_PARAMS); break; // illegal + case 0x20: size = arcompact_handle04_20_dasm(DASM_PARAMS); break; // Jcc + case 0x21: size = arcompact_handle04_21_dasm(DASM_PARAMS); break; // Jcc.D + case 0x22: size = arcompact_handle04_22_dasm(DASM_PARAMS); break; // JLcc + case 0x23: size = arcompact_handle04_23_dasm(DASM_PARAMS); break; // JLcc.D + case 0x24: size = arcompact_handle04_24_dasm(DASM_PARAMS); break; // illegal + case 0x25: size = arcompact_handle04_25_dasm(DASM_PARAMS); break; // illegal + case 0x26: size = arcompact_handle04_26_dasm(DASM_PARAMS); break; // illegal + case 0x27: size = arcompact_handle04_27_dasm(DASM_PARAMS); break; // illegal + case 0x28: size = arcompact_handle04_28_dasm(DASM_PARAMS); break; // LPcc + case 0x29: size = arcompact_handle04_29_dasm(DASM_PARAMS); break; // FLAG + case 0x2a: size = arcompact_handle04_2a_dasm(DASM_PARAMS); break; // LR + case 0x2b: size = arcompact_handle04_2b_dasm(DASM_PARAMS); break; // SR + case 0x2c: size = arcompact_handle04_2c_dasm(DASM_PARAMS); break; // illegal + case 0x2d: size = arcompact_handle04_2d_dasm(DASM_PARAMS); break; // illegal + case 0x2e: size = arcompact_handle04_2e_dasm(DASM_PARAMS); break; // illegal + case 0x2f: size = arcompact_handle04_2f_dasm(DASM_PARAMS); break; // Sub Opcode + case 0x30: size = arcompact_handle04_30_dasm(DASM_PARAMS); break; // LD r-r + case 0x31: size = arcompact_handle04_31_dasm(DASM_PARAMS); break; // LD r-r + case 0x32: size = arcompact_handle04_32_dasm(DASM_PARAMS); break; // LD r-r + case 0x33: size = arcompact_handle04_33_dasm(DASM_PARAMS); break; // LD r-r + case 0x34: size = arcompact_handle04_34_dasm(DASM_PARAMS); break; // LD r-r + case 0x35: size = arcompact_handle04_35_dasm(DASM_PARAMS); break; // LD r-r + case 0x36: size = arcompact_handle04_36_dasm(DASM_PARAMS); break; // LD r-r + case 0x37: size = arcompact_handle04_37_dasm(DASM_PARAMS); break; // LD r-r + case 0x38: size = arcompact_handle04_38_dasm(DASM_PARAMS); break; // illegal + case 0x39: size = arcompact_handle04_39_dasm(DASM_PARAMS); break; // illegal + case 0x3a: size = arcompact_handle04_3a_dasm(DASM_PARAMS); break; // illegal + case 0x3b: size = arcompact_handle04_3b_dasm(DASM_PARAMS); break; // illegal + case 0x3c: size = arcompact_handle04_3c_dasm(DASM_PARAMS); break; // illegal + case 0x3d: size = arcompact_handle04_3d_dasm(DASM_PARAMS); break; // illegal + case 0x3e: size = arcompact_handle04_3e_dasm(DASM_PARAMS); break; // illegal + case 0x3f: size = arcompact_handle04_3f_dasm(DASM_PARAMS); break; // illegal } return size; @@ -633,70 +706,70 @@ int arcompact_handle04_2f_dasm(DASM_OPS_32) switch (subinstr2) { - case 0x00: size = arcompact_handle04_2f_00_dasm(output, pc, op, oprom); break; // ASL - case 0x01: size = arcompact_handle04_2f_01_dasm(output, pc, op, oprom); break; // ASR - case 0x02: size = arcompact_handle04_2f_02_dasm(output, pc, op, oprom); break; // LSR - case 0x03: size = arcompact_handle04_2f_03_dasm(output, pc, op, oprom); break; // ROR - case 0x04: size = arcompact_handle04_2f_04_dasm(output, pc, op, oprom); break; // RCC - case 0x05: size = arcompact_handle04_2f_05_dasm(output, pc, op, oprom); break; // SEXB - case 0x06: size = arcompact_handle04_2f_06_dasm(output, pc, op, oprom); break; // SEXW - case 0x07: size = arcompact_handle04_2f_07_dasm(output, pc, op, oprom); break; // EXTB - case 0x08: size = arcompact_handle04_2f_08_dasm(output, pc, op, oprom); break; // EXTW - case 0x09: size = arcompact_handle04_2f_09_dasm(output, pc, op, oprom); break; // ABS - case 0x0a: size = arcompact_handle04_2f_0a_dasm(output, pc, op, oprom); break; // NOT - case 0x0b: size = arcompact_handle04_2f_0b_dasm(output, pc, op, oprom); break; // RLC - case 0x0c: size = arcompact_handle04_2f_0c_dasm(output, pc, op, oprom); break; // EX - case 0x0d: size = arcompact_handle04_2f_0d_dasm(output, pc, op, oprom); break; // illegal - case 0x0e: size = arcompact_handle04_2f_0e_dasm(output, pc, op, oprom); break; // illegal - case 0x0f: size = arcompact_handle04_2f_0f_dasm(output, pc, op, oprom); break; // illegal - case 0x10: size = arcompact_handle04_2f_10_dasm(output, pc, op, oprom); break; // illegal - case 0x11: size = arcompact_handle04_2f_11_dasm(output, pc, op, oprom); break; // illegal - case 0x12: size = arcompact_handle04_2f_12_dasm(output, pc, op, oprom); break; // illegal - case 0x13: size = arcompact_handle04_2f_13_dasm(output, pc, op, oprom); break; // illegal - case 0x14: size = arcompact_handle04_2f_14_dasm(output, pc, op, oprom); break; // illegal - case 0x15: size = arcompact_handle04_2f_15_dasm(output, pc, op, oprom); break; // illegal - case 0x16: size = arcompact_handle04_2f_16_dasm(output, pc, op, oprom); break; // illegal - case 0x17: size = arcompact_handle04_2f_17_dasm(output, pc, op, oprom); break; // illegal - case 0x18: size = arcompact_handle04_2f_18_dasm(output, pc, op, oprom); break; // illegal - case 0x19: size = arcompact_handle04_2f_19_dasm(output, pc, op, oprom); break; // illegal - case 0x1a: size = arcompact_handle04_2f_1a_dasm(output, pc, op, oprom); break; // illegal - case 0x1b: size = arcompact_handle04_2f_1b_dasm(output, pc, op, oprom); break; // illegal - case 0x1c: size = arcompact_handle04_2f_1c_dasm(output, pc, op, oprom); break; // illegal - case 0x1d: size = arcompact_handle04_2f_1d_dasm(output, pc, op, oprom); break; // illegal - case 0x1e: size = arcompact_handle04_2f_1e_dasm(output, pc, op, oprom); break; // illegal - case 0x1f: size = arcompact_handle04_2f_1f_dasm(output, pc, op, oprom); break; // illegal - case 0x20: size = arcompact_handle04_2f_20_dasm(output, pc, op, oprom); break; // illegal - case 0x21: size = arcompact_handle04_2f_21_dasm(output, pc, op, oprom); break; // illegal - case 0x22: size = arcompact_handle04_2f_22_dasm(output, pc, op, oprom); break; // illegal - case 0x23: size = arcompact_handle04_2f_23_dasm(output, pc, op, oprom); break; // illegal - case 0x24: size = arcompact_handle04_2f_24_dasm(output, pc, op, oprom); break; // illegal - case 0x25: size = arcompact_handle04_2f_25_dasm(output, pc, op, oprom); break; // illegal - case 0x26: size = arcompact_handle04_2f_26_dasm(output, pc, op, oprom); break; // illegal - case 0x27: size = arcompact_handle04_2f_27_dasm(output, pc, op, oprom); break; // illegal - case 0x28: size = arcompact_handle04_2f_28_dasm(output, pc, op, oprom); break; // illegal - case 0x29: size = arcompact_handle04_2f_29_dasm(output, pc, op, oprom); break; // illegal - case 0x2a: size = arcompact_handle04_2f_2a_dasm(output, pc, op, oprom); break; // illegal - case 0x2b: size = arcompact_handle04_2f_2b_dasm(output, pc, op, oprom); break; // illegal - case 0x2c: size = arcompact_handle04_2f_2c_dasm(output, pc, op, oprom); break; // illegal - case 0x2d: size = arcompact_handle04_2f_2d_dasm(output, pc, op, oprom); break; // illegal - case 0x2e: size = arcompact_handle04_2f_2e_dasm(output, pc, op, oprom); break; // illegal - case 0x2f: size = arcompact_handle04_2f_2f_dasm(output, pc, op, oprom); break; // illegal - case 0x30: size = arcompact_handle04_2f_30_dasm(output, pc, op, oprom); break; // illegal - case 0x31: size = arcompact_handle04_2f_31_dasm(output, pc, op, oprom); break; // illegal - case 0x32: size = arcompact_handle04_2f_32_dasm(output, pc, op, oprom); break; // illegal - case 0x33: size = arcompact_handle04_2f_33_dasm(output, pc, op, oprom); break; // illegal - case 0x34: size = arcompact_handle04_2f_34_dasm(output, pc, op, oprom); break; // illegal - case 0x35: size = arcompact_handle04_2f_35_dasm(output, pc, op, oprom); break; // illegal - case 0x36: size = arcompact_handle04_2f_36_dasm(output, pc, op, oprom); break; // illegal - case 0x37: size = arcompact_handle04_2f_37_dasm(output, pc, op, oprom); break; // illegal - case 0x38: size = arcompact_handle04_2f_38_dasm(output, pc, op, oprom); break; // illegal - case 0x39: size = arcompact_handle04_2f_39_dasm(output, pc, op, oprom); break; // illegal - case 0x3a: size = arcompact_handle04_2f_3a_dasm(output, pc, op, oprom); break; // illegal - case 0x3b: size = arcompact_handle04_2f_3b_dasm(output, pc, op, oprom); break; // illegal - case 0x3c: size = arcompact_handle04_2f_3c_dasm(output, pc, op, oprom); break; // illegal - case 0x3d: size = arcompact_handle04_2f_3d_dasm(output, pc, op, oprom); break; // illegal - case 0x3e: size = arcompact_handle04_2f_3e_dasm(output, pc, op, oprom); break; // illegal - case 0x3f: size = arcompact_handle04_2f_3f_dasm(output, pc, op, oprom); break; // ZOPs (Zero Operand Opcodes) + case 0x00: size = arcompact_handle04_2f_00_dasm(DASM_PARAMS); break; // ASL + case 0x01: size = arcompact_handle04_2f_01_dasm(DASM_PARAMS); break; // ASR + case 0x02: size = arcompact_handle04_2f_02_dasm(DASM_PARAMS); break; // LSR + case 0x03: size = arcompact_handle04_2f_03_dasm(DASM_PARAMS); break; // ROR + case 0x04: size = arcompact_handle04_2f_04_dasm(DASM_PARAMS); break; // RCC + case 0x05: size = arcompact_handle04_2f_05_dasm(DASM_PARAMS); break; // SEXB + case 0x06: size = arcompact_handle04_2f_06_dasm(DASM_PARAMS); break; // SEXW + case 0x07: size = arcompact_handle04_2f_07_dasm(DASM_PARAMS); break; // EXTB + case 0x08: size = arcompact_handle04_2f_08_dasm(DASM_PARAMS); break; // EXTW + case 0x09: size = arcompact_handle04_2f_09_dasm(DASM_PARAMS); break; // ABS + case 0x0a: size = arcompact_handle04_2f_0a_dasm(DASM_PARAMS); break; // NOT + case 0x0b: size = arcompact_handle04_2f_0b_dasm(DASM_PARAMS); break; // RLC + case 0x0c: size = arcompact_handle04_2f_0c_dasm(DASM_PARAMS); break; // EX + case 0x0d: size = arcompact_handle04_2f_0d_dasm(DASM_PARAMS); break; // illegal + case 0x0e: size = arcompact_handle04_2f_0e_dasm(DASM_PARAMS); break; // illegal + case 0x0f: size = arcompact_handle04_2f_0f_dasm(DASM_PARAMS); break; // illegal + case 0x10: size = arcompact_handle04_2f_10_dasm(DASM_PARAMS); break; // illegal + case 0x11: size = arcompact_handle04_2f_11_dasm(DASM_PARAMS); break; // illegal + case 0x12: size = arcompact_handle04_2f_12_dasm(DASM_PARAMS); break; // illegal + case 0x13: size = arcompact_handle04_2f_13_dasm(DASM_PARAMS); break; // illegal + case 0x14: size = arcompact_handle04_2f_14_dasm(DASM_PARAMS); break; // illegal + case 0x15: size = arcompact_handle04_2f_15_dasm(DASM_PARAMS); break; // illegal + case 0x16: size = arcompact_handle04_2f_16_dasm(DASM_PARAMS); break; // illegal + case 0x17: size = arcompact_handle04_2f_17_dasm(DASM_PARAMS); break; // illegal + case 0x18: size = arcompact_handle04_2f_18_dasm(DASM_PARAMS); break; // illegal + case 0x19: size = arcompact_handle04_2f_19_dasm(DASM_PARAMS); break; // illegal + case 0x1a: size = arcompact_handle04_2f_1a_dasm(DASM_PARAMS); break; // illegal + case 0x1b: size = arcompact_handle04_2f_1b_dasm(DASM_PARAMS); break; // illegal + case 0x1c: size = arcompact_handle04_2f_1c_dasm(DASM_PARAMS); break; // illegal + case 0x1d: size = arcompact_handle04_2f_1d_dasm(DASM_PARAMS); break; // illegal + case 0x1e: size = arcompact_handle04_2f_1e_dasm(DASM_PARAMS); break; // illegal + case 0x1f: size = arcompact_handle04_2f_1f_dasm(DASM_PARAMS); break; // illegal + case 0x20: size = arcompact_handle04_2f_20_dasm(DASM_PARAMS); break; // illegal + case 0x21: size = arcompact_handle04_2f_21_dasm(DASM_PARAMS); break; // illegal + case 0x22: size = arcompact_handle04_2f_22_dasm(DASM_PARAMS); break; // illegal + case 0x23: size = arcompact_handle04_2f_23_dasm(DASM_PARAMS); break; // illegal + case 0x24: size = arcompact_handle04_2f_24_dasm(DASM_PARAMS); break; // illegal + case 0x25: size = arcompact_handle04_2f_25_dasm(DASM_PARAMS); break; // illegal + case 0x26: size = arcompact_handle04_2f_26_dasm(DASM_PARAMS); break; // illegal + case 0x27: size = arcompact_handle04_2f_27_dasm(DASM_PARAMS); break; // illegal + case 0x28: size = arcompact_handle04_2f_28_dasm(DASM_PARAMS); break; // illegal + case 0x29: size = arcompact_handle04_2f_29_dasm(DASM_PARAMS); break; // illegal + case 0x2a: size = arcompact_handle04_2f_2a_dasm(DASM_PARAMS); break; // illegal + case 0x2b: size = arcompact_handle04_2f_2b_dasm(DASM_PARAMS); break; // illegal + case 0x2c: size = arcompact_handle04_2f_2c_dasm(DASM_PARAMS); break; // illegal + case 0x2d: size = arcompact_handle04_2f_2d_dasm(DASM_PARAMS); break; // illegal + case 0x2e: size = arcompact_handle04_2f_2e_dasm(DASM_PARAMS); break; // illegal + case 0x2f: size = arcompact_handle04_2f_2f_dasm(DASM_PARAMS); break; // illegal + case 0x30: size = arcompact_handle04_2f_30_dasm(DASM_PARAMS); break; // illegal + case 0x31: size = arcompact_handle04_2f_31_dasm(DASM_PARAMS); break; // illegal + case 0x32: size = arcompact_handle04_2f_32_dasm(DASM_PARAMS); break; // illegal + case 0x33: size = arcompact_handle04_2f_33_dasm(DASM_PARAMS); break; // illegal + case 0x34: size = arcompact_handle04_2f_34_dasm(DASM_PARAMS); break; // illegal + case 0x35: size = arcompact_handle04_2f_35_dasm(DASM_PARAMS); break; // illegal + case 0x36: size = arcompact_handle04_2f_36_dasm(DASM_PARAMS); break; // illegal + case 0x37: size = arcompact_handle04_2f_37_dasm(DASM_PARAMS); break; // illegal + case 0x38: size = arcompact_handle04_2f_38_dasm(DASM_PARAMS); break; // illegal + case 0x39: size = arcompact_handle04_2f_39_dasm(DASM_PARAMS); break; // illegal + case 0x3a: size = arcompact_handle04_2f_3a_dasm(DASM_PARAMS); break; // illegal + case 0x3b: size = arcompact_handle04_2f_3b_dasm(DASM_PARAMS); break; // illegal + case 0x3c: size = arcompact_handle04_2f_3c_dasm(DASM_PARAMS); break; // illegal + case 0x3d: size = arcompact_handle04_2f_3d_dasm(DASM_PARAMS); break; // illegal + case 0x3e: size = arcompact_handle04_2f_3e_dasm(DASM_PARAMS); break; // illegal + case 0x3f: size = arcompact_handle04_2f_3f_dasm(DASM_PARAMS); break; // ZOPs (Zero Operand Opcodes) } return size; @@ -766,7 +839,153 @@ int arcompact_handle04_2f_3b_dasm(DASM_OPS_32) { print(" (% int arcompact_handle04_2f_3c_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} int arcompact_handle04_2f_3d_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} int arcompact_handle04_2f_3e_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} -int arcompact_handle04_2f_3f_dasm(DASM_OPS_32) { print("ZOPs (another table) (%08x)", op); return 4;} + +int arcompact_handle04_2f_3f_dasm(DASM_OPS_32) +{ + int size = 4; + UINT8 subinstr3 = (op & 0x07000000) >> 24; + subinstr3 |= ((op & 0x00007000) >> 12) << 3; + + op &= ~0x07007000; + + switch (subinstr3) + { + case 0x00: size = arcompact_handle04_2f_3f_00_dasm(DASM_PARAMS); break; // illegal + case 0x01: size = arcompact_handle04_2f_3f_01_dasm(DASM_PARAMS); break; // SLEEP + case 0x02: size = arcompact_handle04_2f_3f_02_dasm(DASM_PARAMS); break; // SWI / TRAP9 + case 0x03: size = arcompact_handle04_2f_3f_03_dasm(DASM_PARAMS); break; // SYNC + case 0x04: size = arcompact_handle04_2f_3f_04_dasm(DASM_PARAMS); break; // RTIE + case 0x05: size = arcompact_handle04_2f_3f_05_dasm(DASM_PARAMS); break; // BRK + case 0x06: size = arcompact_handle04_2f_3f_06_dasm(DASM_PARAMS); break; // illegal + case 0x07: size = arcompact_handle04_2f_3f_07_dasm(DASM_PARAMS); break; // illegal + case 0x08: size = arcompact_handle04_2f_3f_08_dasm(DASM_PARAMS); break; // illegal + case 0x09: size = arcompact_handle04_2f_3f_09_dasm(DASM_PARAMS); break; // illegal + case 0x0a: size = arcompact_handle04_2f_3f_0a_dasm(DASM_PARAMS); break; // illegal + case 0x0b: size = arcompact_handle04_2f_3f_0b_dasm(DASM_PARAMS); break; // illegal + case 0x0c: size = arcompact_handle04_2f_3f_0c_dasm(DASM_PARAMS); break; // illegal + case 0x0d: size = arcompact_handle04_2f_3f_0d_dasm(DASM_PARAMS); break; // illegal + case 0x0e: size = arcompact_handle04_2f_3f_0e_dasm(DASM_PARAMS); break; // illegal + case 0x0f: size = arcompact_handle04_2f_3f_0f_dasm(DASM_PARAMS); break; // illegal + case 0x10: size = arcompact_handle04_2f_3f_10_dasm(DASM_PARAMS); break; // illegal + case 0x11: size = arcompact_handle04_2f_3f_11_dasm(DASM_PARAMS); break; // illegal + case 0x12: size = arcompact_handle04_2f_3f_12_dasm(DASM_PARAMS); break; // illegal + case 0x13: size = arcompact_handle04_2f_3f_13_dasm(DASM_PARAMS); break; // illegal + case 0x14: size = arcompact_handle04_2f_3f_14_dasm(DASM_PARAMS); break; // illegal + case 0x15: size = arcompact_handle04_2f_3f_15_dasm(DASM_PARAMS); break; // illegal + case 0x16: size = arcompact_handle04_2f_3f_16_dasm(DASM_PARAMS); break; // illegal + case 0x17: size = arcompact_handle04_2f_3f_17_dasm(DASM_PARAMS); break; // illegal + case 0x18: size = arcompact_handle04_2f_3f_18_dasm(DASM_PARAMS); break; // illegal + case 0x19: size = arcompact_handle04_2f_3f_19_dasm(DASM_PARAMS); break; // illegal + case 0x1a: size = arcompact_handle04_2f_3f_1a_dasm(DASM_PARAMS); break; // illegal + case 0x1b: size = arcompact_handle04_2f_3f_1b_dasm(DASM_PARAMS); break; // illegal + case 0x1c: size = arcompact_handle04_2f_3f_1c_dasm(DASM_PARAMS); break; // illegal + case 0x1d: size = arcompact_handle04_2f_3f_1d_dasm(DASM_PARAMS); break; // illegal + case 0x1e: size = arcompact_handle04_2f_3f_1e_dasm(DASM_PARAMS); break; // illegal + case 0x1f: size = arcompact_handle04_2f_3f_1f_dasm(DASM_PARAMS); break; // illegal + case 0x20: size = arcompact_handle04_2f_3f_20_dasm(DASM_PARAMS); break; // illegal + case 0x21: size = arcompact_handle04_2f_3f_21_dasm(DASM_PARAMS); break; // illegal + case 0x22: size = arcompact_handle04_2f_3f_22_dasm(DASM_PARAMS); break; // illegal + case 0x23: size = arcompact_handle04_2f_3f_23_dasm(DASM_PARAMS); break; // illegal + case 0x24: size = arcompact_handle04_2f_3f_24_dasm(DASM_PARAMS); break; // illegal + case 0x25: size = arcompact_handle04_2f_3f_25_dasm(DASM_PARAMS); break; // illegal + case 0x26: size = arcompact_handle04_2f_3f_26_dasm(DASM_PARAMS); break; // illegal + case 0x27: size = arcompact_handle04_2f_3f_27_dasm(DASM_PARAMS); break; // illegal + case 0x28: size = arcompact_handle04_2f_3f_28_dasm(DASM_PARAMS); break; // illegal + case 0x29: size = arcompact_handle04_2f_3f_29_dasm(DASM_PARAMS); break; // illegal + case 0x2a: size = arcompact_handle04_2f_3f_2a_dasm(DASM_PARAMS); break; // illegal + case 0x2b: size = arcompact_handle04_2f_3f_2b_dasm(DASM_PARAMS); break; // illegal + case 0x2c: size = arcompact_handle04_2f_3f_2c_dasm(DASM_PARAMS); break; // illegal + case 0x2d: size = arcompact_handle04_2f_3f_2d_dasm(DASM_PARAMS); break; // illegal + case 0x2e: size = arcompact_handle04_2f_3f_2e_dasm(DASM_PARAMS); break; // illegal + case 0x2f: size = arcompact_handle04_2f_3f_2f_dasm(DASM_PARAMS); break; // illegal + case 0x30: size = arcompact_handle04_2f_3f_30_dasm(DASM_PARAMS); break; // illegal + case 0x31: size = arcompact_handle04_2f_3f_31_dasm(DASM_PARAMS); break; // illegal + case 0x32: size = arcompact_handle04_2f_3f_32_dasm(DASM_PARAMS); break; // illegal + case 0x33: size = arcompact_handle04_2f_3f_33_dasm(DASM_PARAMS); break; // illegal + case 0x34: size = arcompact_handle04_2f_3f_34_dasm(DASM_PARAMS); break; // illegal + case 0x35: size = arcompact_handle04_2f_3f_35_dasm(DASM_PARAMS); break; // illegal + case 0x36: size = arcompact_handle04_2f_3f_36_dasm(DASM_PARAMS); break; // illegal + case 0x37: size = arcompact_handle04_2f_3f_37_dasm(DASM_PARAMS); break; // illegal + case 0x38: size = arcompact_handle04_2f_3f_38_dasm(DASM_PARAMS); break; // illegal + case 0x39: size = arcompact_handle04_2f_3f_39_dasm(DASM_PARAMS); break; // illegal + case 0x3a: size = arcompact_handle04_2f_3f_3a_dasm(DASM_PARAMS); break; // illegal + case 0x3b: size = arcompact_handle04_2f_3f_3b_dasm(DASM_PARAMS); break; // illegal + case 0x3c: size = arcompact_handle04_2f_3f_3c_dasm(DASM_PARAMS); break; // illegal + case 0x3d: size = arcompact_handle04_2f_3f_3d_dasm(DASM_PARAMS); break; // illegal + case 0x3e: size = arcompact_handle04_2f_3f_3e_dasm(DASM_PARAMS); break; // illegal + case 0x3f: size = arcompact_handle04_2f_3f_3f_dasm(DASM_PARAMS); break; // illegal + } + + return size; +} + +int arcompact_handle04_2f_3f_00_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_01_dasm(DASM_OPS_32) { print("SLEEP (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_02_dasm(DASM_OPS_32) { print("SWI / TRAP0 (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_03_dasm(DASM_OPS_32) { print("SYNC (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_04_dasm(DASM_OPS_32) { print("RTIE (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_05_dasm(DASM_OPS_32) { print("BRK (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_06_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_07_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_08_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_09_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_0a_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_0b_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_0c_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_0d_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_0e_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_0f_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_10_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_11_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_12_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_13_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_14_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_15_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_16_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_17_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_18_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_19_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_1a_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_1b_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_1c_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_1d_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_1e_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_1f_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_20_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_21_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_22_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_23_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_24_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_25_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_26_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_27_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_28_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_29_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_2a_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_2b_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_2c_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_2d_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_2e_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_2f_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_30_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_31_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_32_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_33_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_34_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_35_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_36_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_37_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_38_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_39_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_3a_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_3b_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_3c_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_3d_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_3e_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} +int arcompact_handle04_2f_3f_3f_dasm(DASM_OPS_32) { print(" (%08x)", op); return 4;} + + + @@ -853,10 +1072,118 @@ int arcompact_handle0d_dasm(DASM_OPS_16) int arcompact_handle0e_dasm(DASM_OPS_16) { - print("Mov/Cmp/Add (%04x)", op); - return 2; + int size = 2; + UINT8 subinstr = (op & 0x0018) >> 3; + op &= ~0x0018; + + switch (subinstr) + { + case 0x00: size = arcompact_handle0e_00_dasm(DASM_PARAMS); break; // ADD_S + case 0x01: size = arcompact_handle0e_01_dasm(DASM_PARAMS); break; // MOV_S + case 0x02: size = arcompact_handle0e_02_dasm(DASM_PARAMS); break; // CMP_S + case 0x03: size = arcompact_handle0e_03_dasm(DASM_PARAMS); break; // MOV_S + } + return size; } + +#define GROUP_0e_GET_h \ + h = ((op & 0x0007) << 3); \ + h |= ((op & 0x00e0) >> 5); \ + +// this is as messed up as the rest of the 16-bit alignment in LE mode... + +#define GET_LIMM \ + limm = oprom[6] | (oprom[7] << 8); \ + limm |= (oprom[4] << 16) | (oprom[5] << 24); \ + + +int arcompact_handle0e_00_dasm(DASM_OPS_16) +{ + int h; + int size = 2; + + GROUP_0e_GET_h; + + if (h == LIMM_REG) + { + UINT32 limm; + GET_LIMM; + size = 6; + print("ADD_S b <- b + (%08x) (%04x)", limm, op); + } + else + { + + print("ADD_S b <- b + (r%d) (%04x)", h, op); + } + + return size; +} + +int arcompact_handle0e_01_dasm(DASM_OPS_16) +{ + int h; + int size = 2; + GROUP_0e_GET_h; + + if (h == LIMM_REG) + { + UINT32 limm; + GET_LIMM; + size = 6; + print("MOV_S b <- (%08x) (%04x)", limm, op); + } + else + { + print("MOV_S b <- (r%d) (%04x)", h, op); + } + return size; +} + +int arcompact_handle0e_02_dasm(DASM_OPS_16) +{ + int h; + int size = 2; + GROUP_0e_GET_h; + + if (h == LIMM_REG) + { + UINT32 limm; + GET_LIMM; + size = 6; + print("CMP_S b - (%08x) (%04x)", limm, op); + } + else + { + print("CMP_S b - (r%d) (%04x)", h, op); + } + return size; +} + +int arcompact_handle0e_03_dasm(DASM_OPS_16) +{ + int h; + int size = 2; + GROUP_0e_GET_h; + + if (h == LIMM_REG) + { + UINT32 limm; + GET_LIMM; + size = 6; + print("MOV_S (%08x) <- b (%04x)", limm, op); + } + else + { + print("MOV_S (r%d) <- b (%04x)", h, op); + } + + return size; +} + + + int arcompact_handle0f_dasm(DASM_OPS_16) { // General Register Instructions (16-bit) @@ -958,14 +1285,14 @@ int arcompact_handle18_dasm(DASM_OPS_16) switch (subinstr) { - case 0x00: size = arcompact_handle18_00_dasm(output, pc, op, oprom); break; // LD_S (SP) - case 0x01: size = arcompact_handle18_01_dasm(output, pc, op, oprom); break; // LDB_S (SP) - case 0x02: size = arcompact_handle18_02_dasm(output, pc, op, oprom); break; // ST_S (SP) - case 0x03: size = arcompact_handle18_03_dasm(output, pc, op, oprom); break; // STB_S (SP) - case 0x04: size = arcompact_handle18_04_dasm(output, pc, op, oprom); break; // ADD_S (SP) - case 0x05: size = arcompact_handle18_05_dasm(output, pc, op, oprom); break; // subtable 18_05 - case 0x06: size = arcompact_handle18_06_dasm(output, pc, op, oprom); break; // subtable 18_06 - case 0x07: size = arcompact_handle18_07_dasm(output, pc, op, oprom); break; // subtable 18_07 + case 0x00: size = arcompact_handle18_00_dasm(DASM_PARAMS); break; // LD_S (SP) + case 0x01: size = arcompact_handle18_01_dasm(DASM_PARAMS); break; // LDB_S (SP) + case 0x02: size = arcompact_handle18_02_dasm(DASM_PARAMS); break; // ST_S (SP) + case 0x03: size = arcompact_handle18_03_dasm(DASM_PARAMS); break; // STB_S (SP) + case 0x04: size = arcompact_handle18_04_dasm(DASM_PARAMS); break; // ADD_S (SP) + case 0x05: size = arcompact_handle18_05_dasm(DASM_PARAMS); break; // subtable 18_05 + case 0x06: size = arcompact_handle18_06_dasm(DASM_PARAMS); break; // subtable 18_06 + case 0x07: size = arcompact_handle18_07_dasm(DASM_PARAMS); break; // subtable 18_07 } return size; @@ -1015,14 +1342,14 @@ int arcompact_handle18_05_dasm(DASM_OPS_16) switch (subinstr2) { - case 0x00: size = arcompact_handle18_05_00_dasm(output, pc, op, oprom); break; // ADD_S (SP) - case 0x01: size = arcompact_handle18_05_01_dasm(output, pc, op, oprom); break; // SUB_S (SP) - case 0x02: size = arcompact_handle18_05_02_dasm(output, pc, op, oprom); break; // - case 0x03: size = arcompact_handle18_05_03_dasm(output, pc, op, oprom); break; // - case 0x04: size = arcompact_handle18_05_04_dasm(output, pc, op, oprom); break; // - case 0x05: size = arcompact_handle18_05_05_dasm(output, pc, op, oprom); break; // - case 0x06: size = arcompact_handle18_05_06_dasm(output, pc, op, oprom); break; // - case 0x07: size = arcompact_handle18_05_07_dasm(output, pc, op, oprom); break; // + case 0x00: size = arcompact_handle18_05_00_dasm(DASM_PARAMS); break; // ADD_S (SP) + case 0x01: size = arcompact_handle18_05_01_dasm(DASM_PARAMS); break; // SUB_S (SP) + case 0x02: size = arcompact_handle18_05_02_dasm(DASM_PARAMS); break; // + case 0x03: size = arcompact_handle18_05_03_dasm(DASM_PARAMS); break; // + case 0x04: size = arcompact_handle18_05_04_dasm(DASM_PARAMS); break; // + case 0x05: size = arcompact_handle18_05_05_dasm(DASM_PARAMS); break; // + case 0x06: size = arcompact_handle18_05_06_dasm(DASM_PARAMS); break; // + case 0x07: size = arcompact_handle18_05_07_dasm(DASM_PARAMS); break; // } return size; @@ -1064,38 +1391,38 @@ int arcompact_handle18_06_dasm(DASM_OPS_16) switch (subinstr2) { - case 0x00: size = arcompact_handle18_06_00_dasm(output, pc, op, oprom); break; // - case 0x01: size = arcompact_handle18_06_01_dasm(output, pc, op, oprom); break; // POP_S b - case 0x02: size = arcompact_handle18_06_02_dasm(output, pc, op, oprom); break; // - case 0x03: size = arcompact_handle18_06_03_dasm(output, pc, op, oprom); break; // - case 0x04: size = arcompact_handle18_06_04_dasm(output, pc, op, oprom); break; // - case 0x05: size = arcompact_handle18_06_05_dasm(output, pc, op, oprom); break; // - case 0x06: size = arcompact_handle18_06_06_dasm(output, pc, op, oprom); break; // - case 0x07: size = arcompact_handle18_06_07_dasm(output, pc, op, oprom); break; // - case 0x08: size = arcompact_handle18_06_08_dasm(output, pc, op, oprom); break; // - case 0x09: size = arcompact_handle18_06_09_dasm(output, pc, op, oprom); break; // - case 0x0a: size = arcompact_handle18_06_0a_dasm(output, pc, op, oprom); break; // - case 0x0b: size = arcompact_handle18_06_0b_dasm(output, pc, op, oprom); break; // - case 0x0c: size = arcompact_handle18_06_0c_dasm(output, pc, op, oprom); break; // - case 0x0d: size = arcompact_handle18_06_0d_dasm(output, pc, op, oprom); break; // - case 0x0e: size = arcompact_handle18_06_0e_dasm(output, pc, op, oprom); break; // - case 0x0f: size = arcompact_handle18_06_0f_dasm(output, pc, op, oprom); break; // - case 0x10: size = arcompact_handle18_06_10_dasm(output, pc, op, oprom); break; // - case 0x11: size = arcompact_handle18_06_11_dasm(output, pc, op, oprom); break; // POP_S blink - case 0x12: size = arcompact_handle18_06_12_dasm(output, pc, op, oprom); break; // - case 0x13: size = arcompact_handle18_06_13_dasm(output, pc, op, oprom); break; // - case 0x14: size = arcompact_handle18_06_14_dasm(output, pc, op, oprom); break; // - case 0x15: size = arcompact_handle18_06_15_dasm(output, pc, op, oprom); break; // - case 0x16: size = arcompact_handle18_06_16_dasm(output, pc, op, oprom); break; // - case 0x17: size = arcompact_handle18_06_17_dasm(output, pc, op, oprom); break; // - case 0x18: size = arcompact_handle18_06_18_dasm(output, pc, op, oprom); break; // - case 0x19: size = arcompact_handle18_06_19_dasm(output, pc, op, oprom); break; // - case 0x1a: size = arcompact_handle18_06_1a_dasm(output, pc, op, oprom); break; // - case 0x1b: size = arcompact_handle18_06_1b_dasm(output, pc, op, oprom); break; // - case 0x1c: size = arcompact_handle18_06_1c_dasm(output, pc, op, oprom); break; // - case 0x1d: size = arcompact_handle18_06_1d_dasm(output, pc, op, oprom); break; // - case 0x1e: size = arcompact_handle18_06_1e_dasm(output, pc, op, oprom); break; // - case 0x1f: size = arcompact_handle18_06_1f_dasm(output, pc, op, oprom); break; // + case 0x00: size = arcompact_handle18_06_00_dasm(DASM_PARAMS); break; // + case 0x01: size = arcompact_handle18_06_01_dasm(DASM_PARAMS); break; // POP_S b + case 0x02: size = arcompact_handle18_06_02_dasm(DASM_PARAMS); break; // + case 0x03: size = arcompact_handle18_06_03_dasm(DASM_PARAMS); break; // + case 0x04: size = arcompact_handle18_06_04_dasm(DASM_PARAMS); break; // + case 0x05: size = arcompact_handle18_06_05_dasm(DASM_PARAMS); break; // + case 0x06: size = arcompact_handle18_06_06_dasm(DASM_PARAMS); break; // + case 0x07: size = arcompact_handle18_06_07_dasm(DASM_PARAMS); break; // + case 0x08: size = arcompact_handle18_06_08_dasm(DASM_PARAMS); break; // + case 0x09: size = arcompact_handle18_06_09_dasm(DASM_PARAMS); break; // + case 0x0a: size = arcompact_handle18_06_0a_dasm(DASM_PARAMS); break; // + case 0x0b: size = arcompact_handle18_06_0b_dasm(DASM_PARAMS); break; // + case 0x0c: size = arcompact_handle18_06_0c_dasm(DASM_PARAMS); break; // + case 0x0d: size = arcompact_handle18_06_0d_dasm(DASM_PARAMS); break; // + case 0x0e: size = arcompact_handle18_06_0e_dasm(DASM_PARAMS); break; // + case 0x0f: size = arcompact_handle18_06_0f_dasm(DASM_PARAMS); break; // + case 0x10: size = arcompact_handle18_06_10_dasm(DASM_PARAMS); break; // + case 0x11: size = arcompact_handle18_06_11_dasm(DASM_PARAMS); break; // POP_S blink + case 0x12: size = arcompact_handle18_06_12_dasm(DASM_PARAMS); break; // + case 0x13: size = arcompact_handle18_06_13_dasm(DASM_PARAMS); break; // + case 0x14: size = arcompact_handle18_06_14_dasm(DASM_PARAMS); break; // + case 0x15: size = arcompact_handle18_06_15_dasm(DASM_PARAMS); break; // + case 0x16: size = arcompact_handle18_06_16_dasm(DASM_PARAMS); break; // + case 0x17: size = arcompact_handle18_06_17_dasm(DASM_PARAMS); break; // + case 0x18: size = arcompact_handle18_06_18_dasm(DASM_PARAMS); break; // + case 0x19: size = arcompact_handle18_06_19_dasm(DASM_PARAMS); break; // + case 0x1a: size = arcompact_handle18_06_1a_dasm(DASM_PARAMS); break; // + case 0x1b: size = arcompact_handle18_06_1b_dasm(DASM_PARAMS); break; // + case 0x1c: size = arcompact_handle18_06_1c_dasm(DASM_PARAMS); break; // + case 0x1d: size = arcompact_handle18_06_1d_dasm(DASM_PARAMS); break; // + case 0x1e: size = arcompact_handle18_06_1e_dasm(DASM_PARAMS); break; // + case 0x1f: size = arcompact_handle18_06_1f_dasm(DASM_PARAMS); break; // } return size; @@ -1170,38 +1497,38 @@ int arcompact_handle18_07_dasm(DASM_OPS_16) switch (subinstr2) { - case 0x00: size = arcompact_handle18_07_00_dasm(output, pc, op, oprom); break; // - case 0x01: size = arcompact_handle18_07_01_dasm(output, pc, op, oprom); break; // PUSH_S b - case 0x02: size = arcompact_handle18_07_02_dasm(output, pc, op, oprom); break; // - case 0x03: size = arcompact_handle18_07_03_dasm(output, pc, op, oprom); break; // - case 0x04: size = arcompact_handle18_07_04_dasm(output, pc, op, oprom); break; // - case 0x05: size = arcompact_handle18_07_05_dasm(output, pc, op, oprom); break; // - case 0x06: size = arcompact_handle18_07_06_dasm(output, pc, op, oprom); break; // - case 0x07: size = arcompact_handle18_07_07_dasm(output, pc, op, oprom); break; // - case 0x08: size = arcompact_handle18_07_08_dasm(output, pc, op, oprom); break; // - case 0x09: size = arcompact_handle18_07_09_dasm(output, pc, op, oprom); break; // - case 0x0a: size = arcompact_handle18_07_0a_dasm(output, pc, op, oprom); break; // - case 0x0b: size = arcompact_handle18_07_0b_dasm(output, pc, op, oprom); break; // - case 0x0c: size = arcompact_handle18_07_0c_dasm(output, pc, op, oprom); break; // - case 0x0d: size = arcompact_handle18_07_0d_dasm(output, pc, op, oprom); break; // - case 0x0e: size = arcompact_handle18_07_0e_dasm(output, pc, op, oprom); break; // - case 0x0f: size = arcompact_handle18_07_0f_dasm(output, pc, op, oprom); break; // - case 0x10: size = arcompact_handle18_07_10_dasm(output, pc, op, oprom); break; // - case 0x11: size = arcompact_handle18_07_11_dasm(output, pc, op, oprom); break; // PUSH_S blink - case 0x12: size = arcompact_handle18_07_12_dasm(output, pc, op, oprom); break; // - case 0x13: size = arcompact_handle18_07_13_dasm(output, pc, op, oprom); break; // - case 0x14: size = arcompact_handle18_07_14_dasm(output, pc, op, oprom); break; // - case 0x15: size = arcompact_handle18_07_15_dasm(output, pc, op, oprom); break; // - case 0x16: size = arcompact_handle18_07_16_dasm(output, pc, op, oprom); break; // - case 0x17: size = arcompact_handle18_07_17_dasm(output, pc, op, oprom); break; // - case 0x18: size = arcompact_handle18_07_18_dasm(output, pc, op, oprom); break; // - case 0x19: size = arcompact_handle18_07_19_dasm(output, pc, op, oprom); break; // - case 0x1a: size = arcompact_handle18_07_1a_dasm(output, pc, op, oprom); break; // - case 0x1b: size = arcompact_handle18_07_1b_dasm(output, pc, op, oprom); break; // - case 0x1c: size = arcompact_handle18_07_1c_dasm(output, pc, op, oprom); break; // - case 0x1d: size = arcompact_handle18_07_1d_dasm(output, pc, op, oprom); break; // - case 0x1e: size = arcompact_handle18_07_1e_dasm(output, pc, op, oprom); break; // - case 0x1f: size = arcompact_handle18_07_1f_dasm(output, pc, op, oprom); break; // + case 0x00: size = arcompact_handle18_07_00_dasm(DASM_PARAMS); break; // + case 0x01: size = arcompact_handle18_07_01_dasm(DASM_PARAMS); break; // PUSH_S b + case 0x02: size = arcompact_handle18_07_02_dasm(DASM_PARAMS); break; // + case 0x03: size = arcompact_handle18_07_03_dasm(DASM_PARAMS); break; // + case 0x04: size = arcompact_handle18_07_04_dasm(DASM_PARAMS); break; // + case 0x05: size = arcompact_handle18_07_05_dasm(DASM_PARAMS); break; // + case 0x06: size = arcompact_handle18_07_06_dasm(DASM_PARAMS); break; // + case 0x07: size = arcompact_handle18_07_07_dasm(DASM_PARAMS); break; // + case 0x08: size = arcompact_handle18_07_08_dasm(DASM_PARAMS); break; // + case 0x09: size = arcompact_handle18_07_09_dasm(DASM_PARAMS); break; // + case 0x0a: size = arcompact_handle18_07_0a_dasm(DASM_PARAMS); break; // + case 0x0b: size = arcompact_handle18_07_0b_dasm(DASM_PARAMS); break; // + case 0x0c: size = arcompact_handle18_07_0c_dasm(DASM_PARAMS); break; // + case 0x0d: size = arcompact_handle18_07_0d_dasm(DASM_PARAMS); break; // + case 0x0e: size = arcompact_handle18_07_0e_dasm(DASM_PARAMS); break; // + case 0x0f: size = arcompact_handle18_07_0f_dasm(DASM_PARAMS); break; // + case 0x10: size = arcompact_handle18_07_10_dasm(DASM_PARAMS); break; // + case 0x11: size = arcompact_handle18_07_11_dasm(DASM_PARAMS); break; // PUSH_S blink + case 0x12: size = arcompact_handle18_07_12_dasm(DASM_PARAMS); break; // + case 0x13: size = arcompact_handle18_07_13_dasm(DASM_PARAMS); break; // + case 0x14: size = arcompact_handle18_07_14_dasm(DASM_PARAMS); break; // + case 0x15: size = arcompact_handle18_07_15_dasm(DASM_PARAMS); break; // + case 0x16: size = arcompact_handle18_07_16_dasm(DASM_PARAMS); break; // + case 0x17: size = arcompact_handle18_07_17_dasm(DASM_PARAMS); break; // + case 0x18: size = arcompact_handle18_07_18_dasm(DASM_PARAMS); break; // + case 0x19: size = arcompact_handle18_07_19_dasm(DASM_PARAMS); break; // + case 0x1a: size = arcompact_handle18_07_1a_dasm(DASM_PARAMS); break; // + case 0x1b: size = arcompact_handle18_07_1b_dasm(DASM_PARAMS); break; // + case 0x1c: size = arcompact_handle18_07_1c_dasm(DASM_PARAMS); break; // + case 0x1d: size = arcompact_handle18_07_1d_dasm(DASM_PARAMS); break; // + case 0x1e: size = arcompact_handle18_07_1e_dasm(DASM_PARAMS); break; // + case 0x1f: size = arcompact_handle18_07_1f_dasm(DASM_PARAMS); break; // } return size; @@ -1328,18 +1655,18 @@ CPU_DISASSEMBLE(arcompact) switch (instruction) // 32-bit instructions (with optional extra dword for immediate data) { - case 0x00: size = arcompact_handle00_dasm(output, pc, op, oprom); break; // Bcc - case 0x01: size = arcompact_handle01_dasm(output, pc, op, oprom); break; // BLcc/BRcc - case 0x02: size = arcompact_handle02_dasm(output, pc, op, oprom); break; // LD r+o - case 0x03: size = arcompact_handle03_dasm(output, pc, op, oprom); break; // ST r+o - case 0x04: size = arcompact_handle04_dasm(output, pc, op, oprom); break; // op a,b,c (basecase) - case 0x05: size = arcompact_handle05_dasm(output, pc, op, oprom); break; // op a,b,c (05 ARC ext) - case 0x06: size = arcompact_handle06_dasm(output, pc, op, oprom); break; // op a,b,c (06 ARC ext) - case 0x07: size = arcompact_handle07_dasm(output, pc, op, oprom); break; // op a,b,c (07 User ext) - case 0x08: size = arcompact_handle08_dasm(output, pc, op, oprom); break; // op a,b,c (08 User ext) - case 0x09: size = arcompact_handle09_dasm(output, pc, op, oprom); break; // op a,b,c (09 Market ext) - case 0x0a: size = arcompact_handle0a_dasm(output, pc, op, oprom); break; // op a,b,c (0a Market ext) - case 0x0b: size = arcompact_handle0b_dasm(output, pc, op, oprom); break; // op a,b,c (0b Market ext) + case 0x00: size = arcompact_handle00_dasm(DASM_PARAMS); break; // Bcc + case 0x01: size = arcompact_handle01_dasm(DASM_PARAMS); break; // BLcc/BRcc + case 0x02: size = arcompact_handle02_dasm(DASM_PARAMS); break; // LD r+o + case 0x03: size = arcompact_handle03_dasm(DASM_PARAMS); break; // ST r+o + case 0x04: size = arcompact_handle04_dasm(DASM_PARAMS); break; // op a,b,c (basecase) + case 0x05: size = arcompact_handle05_dasm(DASM_PARAMS); break; // op a,b,c (05 ARC ext) + case 0x06: size = arcompact_handle06_dasm(DASM_PARAMS); break; // op a,b,c (06 ARC ext) + case 0x07: size = arcompact_handle07_dasm(DASM_PARAMS); break; // op a,b,c (07 User ext) + case 0x08: size = arcompact_handle08_dasm(DASM_PARAMS); break; // op a,b,c (08 User ext) + case 0x09: size = arcompact_handle09_dasm(DASM_PARAMS); break; // op a,b,c (09 Market ext) + case 0x0a: size = arcompact_handle0a_dasm(DASM_PARAMS); break; // op a,b,c (0a Market ext) + case 0x0b: size = arcompact_handle0b_dasm(DASM_PARAMS); break; // op a,b,c (0b Market ext) } } else @@ -1350,26 +1677,26 @@ CPU_DISASSEMBLE(arcompact) switch (instruction) // 16-bit instructions { - case 0x0c: size = arcompact_handle0c_dasm(output, pc, op, oprom); break; // Load/Add reg-reg - case 0x0d: size = arcompact_handle0d_dasm(output, pc, op, oprom); break; // Add/Sub/Shft imm - case 0x0e: size = arcompact_handle0e_dasm(output, pc, op, oprom); break; // Mov/Cmp/Add - case 0x0f: size = arcompact_handle0f_dasm(output, pc, op, oprom); break; // op_S b,b,c (single 16-bit ops) - case 0x10: size = arcompact_handle10_dasm(output, pc, op, oprom); break; // LD_S - case 0x11: size = arcompact_handle11_dasm(output, pc, op, oprom); break; // LDB_S - case 0x12: size = arcompact_handle12_dasm(output, pc, op, oprom); break; // LDW_S - case 0x13: size = arcompact_handle13_dasm(output, pc, op, oprom); break; // LSW_S.X - case 0x14: size = arcompact_handle14_dasm(output, pc, op, oprom); break; // ST_S - case 0x15: size = arcompact_handle15_dasm(output, pc, op, oprom); break; // STB_S - case 0x16: size = arcompact_handle16_dasm(output, pc, op, oprom); break; // STW_S - case 0x17: size = arcompact_handle17_dasm(output, pc, op, oprom); break; // Shift/Sub/Bit - case 0x18: size = arcompact_handle18_dasm(output, pc, op, oprom); break; // Stack Instr - case 0x19: size = arcompact_handle19_dasm(output, pc, op, oprom); break; // GP Instr - case 0x1a: size = arcompact_handle1a_dasm(output, pc, op, oprom); break; // PCL Instr - case 0x1b: size = arcompact_handle1b_dasm(output, pc, op, oprom); break; // MOV_S - case 0x1c: size = arcompact_handle1c_dasm(output, pc, op, oprom); break; // ADD_S/CMP_S - case 0x1d: size = arcompact_handle1d_dasm(output, pc, op, oprom); break; // BRcc_S - case 0x1e: size = arcompact_handle1e_dasm(output, pc, op, oprom); break; // Bcc_S - case 0x1f: size = arcompact_handle1f_dasm(output, pc, op, oprom); break; // BL_S + case 0x0c: size = arcompact_handle0c_dasm(DASM_PARAMS); break; // Load/Add reg-reg + case 0x0d: size = arcompact_handle0d_dasm(DASM_PARAMS); break; // Add/Sub/Shft imm + case 0x0e: size = arcompact_handle0e_dasm(DASM_PARAMS); break; // Mov/Cmp/Add + case 0x0f: size = arcompact_handle0f_dasm(DASM_PARAMS); break; // op_S b,b,c (single 16-bit ops) + case 0x10: size = arcompact_handle10_dasm(DASM_PARAMS); break; // LD_S + case 0x11: size = arcompact_handle11_dasm(DASM_PARAMS); break; // LDB_S + case 0x12: size = arcompact_handle12_dasm(DASM_PARAMS); break; // LDW_S + case 0x13: size = arcompact_handle13_dasm(DASM_PARAMS); break; // LSW_S.X + case 0x14: size = arcompact_handle14_dasm(DASM_PARAMS); break; // ST_S + case 0x15: size = arcompact_handle15_dasm(DASM_PARAMS); break; // STB_S + case 0x16: size = arcompact_handle16_dasm(DASM_PARAMS); break; // STW_S + case 0x17: size = arcompact_handle17_dasm(DASM_PARAMS); break; // Shift/Sub/Bit + case 0x18: size = arcompact_handle18_dasm(DASM_PARAMS); break; // Stack Instr + case 0x19: size = arcompact_handle19_dasm(DASM_PARAMS); break; // GP Instr + case 0x1a: size = arcompact_handle1a_dasm(DASM_PARAMS); break; // PCL Instr + case 0x1b: size = arcompact_handle1b_dasm(DASM_PARAMS); break; // MOV_S + case 0x1c: size = arcompact_handle1c_dasm(DASM_PARAMS); break; // ADD_S/CMP_S + case 0x1d: size = arcompact_handle1d_dasm(DASM_PARAMS); break; // BRcc_S + case 0x1e: size = arcompact_handle1e_dasm(DASM_PARAMS); break; // Bcc_S + case 0x1f: size = arcompact_handle1f_dasm(DASM_PARAMS); break; // BL_S } }