--- np2/i286c/i286c_mn.c 2003/10/19 14:56:15 1.6 +++ np2/i286c/i286c_mn.c 2003/11/21 06:51:11 1.10 @@ -43,7 +43,7 @@ I286FN _add_ea_r8(void) { // 00: ad PREPART_EA_REG8(op, src); if (op >= 0xc0) { I286_WORKCLOCK(2); - out = reg8_b20[op]; + out = REG8_B20(op); } else { I286_WORKCLOCK(7); @@ -73,7 +73,7 @@ I286FN _add_ea_r16(void) { // 01: a PREPART_EA_REG16(op, src); if (op >= 0xc0) { I286_WORKCLOCK(2); - out = reg16_b20[op]; + out = REG16_B20(op); } else { I286_WORKCLOCK(7); @@ -163,7 +163,7 @@ I286FN _or_ea_r8(void) { // 08: or PREPART_EA_REG8(op, src); if (op >= 0xc0) { I286_WORKCLOCK(2); - out = reg8_b20[op]; + out = REG8_B20(op); } else { I286_WORKCLOCK(7); @@ -190,7 +190,7 @@ I286FN _or_ea_r16(void) { // 09: o PREPART_EA_REG16(op, src); if (op >= 0xc0) { I286_WORKCLOCK(2); - out = reg16_b20[op]; + out = REG16_B20(op); } else { I286_WORKCLOCK(7); @@ -261,7 +261,7 @@ I286FN _adc_ea_r8(void) { // 10: ad PREPART_EA_REG8(op, src); if (op >= 0xc0) { I286_WORKCLOCK(2); - out = reg8_b20[op]; + out = REG8_B20(op); } else { I286_WORKCLOCK(7); @@ -291,7 +291,7 @@ I286FN _adc_ea_r16(void) { // 11: a PREPART_EA_REG16(op, src); if (op >= 0xc0) { I286_WORKCLOCK(2); - out = reg16_b20[op]; + out = REG16_B20(op); } else { I286_WORKCLOCK(7); @@ -384,7 +384,7 @@ I286FN _sbb_ea_r8(void) { // 18: sb PREPART_EA_REG8(op, src); if (op >= 0xc0) { I286_WORKCLOCK(2); - out = reg8_b20[op]; + out = REG8_B20(op); } else { I286_WORKCLOCK(7); @@ -414,7 +414,7 @@ I286FN _sbb_ea_r16(void) { // 19: s PREPART_EA_REG16(op, src); if (op >= 0xc0) { I286_WORKCLOCK(2); - out = reg16_b20[op]; + out = REG16_B20(op); } else { I286_WORKCLOCK(7); @@ -505,7 +505,7 @@ I286FN _and_ea_r8(void) { // 20: an PREPART_EA_REG8(op, src); if (op >= 0xc0) { I286_WORKCLOCK(2); - out = reg8_b20[op]; + out = REG8_B20(op); } else { I286_WORKCLOCK(7); @@ -532,7 +532,7 @@ I286FN _and_ea_r16(void) { // 21: a PREPART_EA_REG16(op, src); if (op >= 0xc0) { I286_WORKCLOCK(2); - out = reg16_b20[op]; + out = REG16_B20(op); } else { I286_WORKCLOCK(7); @@ -634,7 +634,7 @@ I286FN _sub_ea_r8(void) { // 28: su PREPART_EA_REG8(op, src); if (op >= 0xc0) { I286_WORKCLOCK(2); - out = reg8_b20[op]; + out = REG8_B20(op); } else { I286_WORKCLOCK(7); @@ -664,7 +664,7 @@ I286FN _sub_ea_r16(void) { // 29: s PREPART_EA_REG16(op, src); if (op >= 0xc0) { I286_WORKCLOCK(2); - out = reg16_b20[op]; + out = REG16_B20(op); } else { I286_WORKCLOCK(7); @@ -776,7 +776,7 @@ I286FN _xor_ea_r8(void) { // 30: xo PREPART_EA_REG8(op, src); if (op >= 0xc0) { I286_WORKCLOCK(2); - out = reg8_b20[op]; + out = REG8_B20(op); } else { I286_WORKCLOCK(7); @@ -803,7 +803,7 @@ I286FN _xor_ea_r16(void) { // 31: x PREPART_EA_REG16(op, src); if (op >= 0xc0) { I286_WORKCLOCK(2); - out = reg16_b20[op]; + out = REG16_B20(op); } else { I286_WORKCLOCK(7); @@ -857,7 +857,7 @@ I286FN _xor_ax_data16(void) { // 35: WORD_XOR(I286_AX, src); } -I286FN _segprefix_ss(void) { // 36: cs: +I286FN _segprefix_ss(void) { // 36: ss: SS_FIX = SS_BASE; DS_FIX = SS_BASE; @@ -897,7 +897,7 @@ I286FN _cmp_ea_r8(void) { // 38: cm PREPART_EA_REG8(op, src); if (op >= 0xc0) { I286_WORKCLOCK(2); - dst = *(reg8_b20[op]); + dst = *(REG8_B20(op)); BYTE_SUB(res, dst, src); } else { @@ -917,7 +917,7 @@ I286FN _cmp_ea_r16(void) { // 39: c PREPART_EA_REG16(op, src); if (op >= 0xc0) { I286_WORKCLOCK(2); - dst = *(reg16_b20[op]); + dst = *(REG16_B20(op)); WORD_SUB(res, dst, src); } else { @@ -1032,7 +1032,7 @@ I286FN _pop_ax(void) REGPOP(I286_AX, 5) I286FN _pop_cx(void) REGPOP(I286_CX, 5) // 59: pop cx I286FN _pop_dx(void) REGPOP(I286_DX, 5) // 5A: pop dx I286FN _pop_bx(void) REGPOP(I286_BX, 5) // 5B: pop bx -I286FN _pop_sp(void) REGPOP(I286_SP, 5) // 5C: pop sp +I286FN _pop_sp(void) SP_POP(I286_SP, 5) // 5C: pop sp I286FN _pop_bp(void) REGPOP(I286_BP, 5) // 5D: pop bp I286FN _pop_si(void) REGPOP(I286_SI, 5) // 5E: pop si I286FN _pop_di(void) REGPOP(I286_DI, 5) // 5F: pop di @@ -1076,7 +1076,7 @@ I286FN _bound(void) { // 62: bound I286_WORKCLOCK(13); // ToDo GET_PCBYTE(op); if (op < 0xc0) { - reg = *(reg16_b53[op]); + reg = *(REG16_B53(op)); madr = c_calc_ea_dst[op](); if (reg >= i286_memoryread_w(madr)) { madr += 2; // ToDo @@ -1282,7 +1282,7 @@ I286FN _calc_ea8_i8(void) { // 80: o GET_PCBYTE(op) if (op >= 0xc0) { I286_WORKCLOCK(3); - out = reg8_b20[op]; + out = REG8_B20(op); } else { I286_WORKCLOCK(7); @@ -1306,7 +1306,7 @@ I286FN _calc_ea16_i16(void) { // 81: GET_PCBYTE(op) if (op >= 0xc0) { I286_WORKCLOCK(3); - out = reg16_b20[op]; + out = REG16_B20(op); } else { I286_WORKCLOCK(7); @@ -1332,7 +1332,7 @@ I286FN _calc_ea16_i8(void) { // 83: o GET_PCBYTE(op) if (op >= 0xc0) { I286_WORKCLOCK(3); - out = reg16_b20[op]; + out = REG16_B20(op); } else { I286_WORKCLOCK(7); @@ -1359,7 +1359,7 @@ I286FN _test_ea_r8(void) { // 84: te PREPART_EA_REG8(op, src); if (op >= 0xc0) { I286_WORKCLOCK(2); - out = reg8_b20[op]; + out = REG8_B20(op); } else { I286_WORKCLOCK(6); @@ -1386,7 +1386,7 @@ I286FN _test_ea_r16(void) { // 85: t PREPART_EA_REG16(op, src); if (op >= 0xc0) { I286_WORKCLOCK(2); - out = reg16_b20[op]; + out = REG16_B20(op); } else { I286_WORKCLOCK(7); @@ -1412,7 +1412,7 @@ I286FN _xchg_ea_r8(void) { // 86: xc PREPART_EA_REG8P(op, src); if (op >= 0xc0) { I286_WORKCLOCK(3); - out = reg8_b20[op]; + out = REG8_B20(op); } else { I286_WORKCLOCK(5); @@ -1438,7 +1438,7 @@ I286FN _xchg_ea_r16(void) { // 87: x PREPART_EA_REG16P(op, src); if (op >= 0xc0) { I286_WORKCLOCK(3); - out = reg16_b20[op]; + out = REG16_B20(op); } else { I286_WORKCLOCK(5); @@ -1463,7 +1463,7 @@ I286FN _mov_ea_r8(void) { // 88: mov PREPART_EA_REG8(op, src) if (op >= 0xc0) { I286_WORKCLOCK(2); - *(reg8_b20[op]) = src; + *(REG8_B20(op)) = src; } else { I286_WORKCLOCK(3); @@ -1480,7 +1480,7 @@ I286FN _mov_ea_r16(void) { // 89: mo PREPART_EA_REG16(op, src); if (op >= 0xc0) { I286_WORKCLOCK(2); - *(reg16_b20[op]) = src; + *(REG16_B20(op)) = src; } else { I286_WORKCLOCK(3); @@ -1517,7 +1517,7 @@ I286FN _mov_ea_seg(void) { // 8C: mo tmp = *SEGMENTPTR((op >> 3) & 3); if (op >= 0xc0) { I286_WORKCLOCK(2); - *(reg16_b20[op]) = tmp; + *(REG16_B20(op)) = tmp; } else { I286_WORKCLOCK(3); @@ -1532,7 +1532,7 @@ I286FN _lea_r16_ea(void) { // 8D: le I286_WORKCLOCK(3); GET_PCBYTE(op) if (op < 0xc0) { - *(reg16_b53[op]) = c_calc_lea[op](); + *(REG16_B53(op)) = c_calc_lea[op](); } else { INT_NUM(6, I286_SP - 2); @@ -1549,7 +1549,7 @@ I286FN _mov_seg_ea(void) { // 8E: mo GET_PCBYTE(op); if (op >= 0xc0) { I286_WORKCLOCK(2); - tmp = *(reg16_b20[op]); + tmp = *(REG16_B20(op)); } else { I286_WORKCLOCK(5); @@ -1593,7 +1593,7 @@ I286FN _pop_ea(void) { // 8F: pop i286_memorywrite_w(c_calc_ea_dst[op](), tmp); } else { - *(reg16_b20[op]) = tmp; + *(REG16_B20(op)) = tmp; } } @@ -1904,7 +1904,7 @@ I286FN _shift_ea8_data8(void) { // C0 GET_PCBYTE(op) if (op >= 0xc0) { I286_WORKCLOCK(5); - out = reg8_b20[op]; + out = REG8_B20(op); } else { I286_WORKCLOCK(8); @@ -1932,7 +1932,7 @@ I286FN _shift_ea16_data8(void) { // C1 GET_PCBYTE(op) if (op >= 0xc0) { I286_WORKCLOCK(5); - out = reg16_b20[op]; + out = REG16_B20(op); } else { I286_WORKCLOCK(8); @@ -1975,7 +1975,7 @@ I286FN _les_r16_ea(void) { // C4: le GET_PCBYTE(op) if (op < 0xc0) { ad = c_get_ea[op](); - *(reg16_b53[op]) = i286_memoryread_w(ad + EA_FIX); + *(REG16_B53(op)) = i286_memoryread_w(ad + EA_FIX); ad += 2; I286_ES = i286_memoryread_w(ad + EA_FIX); ES_BASE = I286_ES << 4; @@ -1994,7 +1994,7 @@ I286FN _lds_r16_ea(void) { // C5: ld GET_PCBYTE(op) if (op < 0xc0) { ad = c_get_ea[op](); - *(reg16_b53[op]) = i286_memoryread_w(ad + EA_FIX); + *(REG16_B53(op)) = i286_memoryread_w(ad + EA_FIX); ad += 2; I286_DS = i286_memoryread_w(ad + EA_FIX); DS_BASE = I286_DS << 4; @@ -2012,7 +2012,7 @@ I286FN _mov_ea8_data8(void) { // C6: GET_PCBYTE(op) if (op >= 0xc0) { I286_WORKCLOCK(2); - GET_PCBYTE(*(reg8_b53[op])) + GET_PCBYTE(*(REG8_B53(op))) } else { UINT ad; @@ -2031,7 +2031,7 @@ I286FN _mov_ea16_data16(void) { // C7 GET_PCBYTE(op) if (op >= 0xc0) { I286_WORKCLOCK(2); - GET_PCWORD(*(reg16_b53[op])) + GET_PCWORD(*(REG16_B53(op))) } else { UINT ad; @@ -2073,10 +2073,18 @@ I286FN _enter(void) { // C8: enter bp = I286_BP; I286_BP = I286_SP; while(level--) { +#if 1 // なにやってんだヲレ + UINT16 val; + bp -= 2; + I286_SP -= 2; + val = i286_memoryread_w(bp + SS_BASE); + i286_memorywrite_w(I286_SP + SS_BASE, val); +#else UINT16 val = i286_memoryread_w(bp + SS_BASE); i286_memorywrite_w(I286_SP + SS_BASE, val); bp -= 2; I286_SP -= 2; +#endif } REGPUSH0(I286_BP) I286_SP -= dimsize; @@ -2084,7 +2092,7 @@ I286FN _enter(void) { // C8: enter } } -I286FN leave(void) { // C9: leave +I286FN fleave(void) { // C9: leave I286_WORKCLOCK(5); I286_SP = I286_BP; @@ -2158,7 +2166,7 @@ I286FN _shift_ea8_1(void) { // D0: sh GET_PCBYTE(op) if (op >= 0xc0) { I286_WORKCLOCK(2); - out = reg8_b20[op]; + out = REG8_B20(op); } else { I286_WORKCLOCK(7); @@ -2181,7 +2189,7 @@ I286FN _shift_ea16_1(void) { // D1: sh GET_PCBYTE(op) if (op >= 0xc0) { I286_WORKCLOCK(2); - out = reg16_b20[op]; + out = REG16_B20(op); } else { I286_WORKCLOCK(7); @@ -2205,7 +2213,7 @@ I286FN _shift_ea8_cl(void) { // D2: sh GET_PCBYTE(op) if (op >= 0xc0) { I286_WORKCLOCK(5); - out = reg8_b20[op]; + out = REG8_B20(op); } else { I286_WORKCLOCK(8); @@ -2233,7 +2241,7 @@ I286FN _shift_ea16_cl(void) { // D3: s GET_PCBYTE(op) if (op >= 0xc0) { I286_WORKCLOCK(5); - out = reg16_b20[op]; + out = REG16_B20(op); } else { I286_WORKCLOCK(8); @@ -2762,7 +2770,7 @@ const I286OP i286op[] = { _mov_ea8_data8, // C6: mov EA8, DATA8 _mov_ea16_data16, // C7: mov EA16, DATA16 _enter, // C8: enter DATA16, DATA8 - leave, // C9: leave + fleave, // C9: leave _ret_far_data16, // CA: ret far DATA16 _ret_far, // CB: ret far _int_03, // CC: int 3 @@ -3075,7 +3083,7 @@ const I286OP i286op_repe[] = { i286c_repe_cmpsw, // A7: repe cmpsw _test_al_data8, // A8: test al, DATA8 _test_ax_data16, // A9: test ax, DATA16 - i286c_rep_stosb, // AA: rep stosw + i286c_rep_stosb, // AA: rep stosb i286c_rep_stosw, // AB: rep stosw i286c_rep_lodsb, // AC: rep lodsb i286c_rep_lodsw, // AD: rep lodsw @@ -3108,7 +3116,7 @@ const I286OP i286op_repe[] = { _mov_ea8_data8, // C6: mov EA8, DATA8 _mov_ea16_data16, // C7: mov EA16, DATA16 _enter, // C8: enter DATA16, DATA8 - leave, // C9: leave + fleave, // C9: leave _ret_far_data16, // CA: ret far DATA16 _ret_far, // CB: ret far _int_03, // CC: int 3 @@ -3420,7 +3428,7 @@ const I286OP i286op_repne[] = { i286c_repne_cmpsw, // A7: repne cmpsw _test_al_data8, // A8: test al, DATA8 _test_ax_data16, // A9: test ax, DATA16 - i286c_rep_stosb, // AA: rep stosw + i286c_rep_stosb, // AA: rep stosb i286c_rep_stosw, // AB: rep stosw i286c_rep_lodsb, // AC: rep lodsb i286c_rep_lodsw, // AD: rep lodsw @@ -3453,7 +3461,7 @@ const I286OP i286op_repne[] = { _mov_ea8_data8, // C6: mov EA8, DATA8 _mov_ea16_data16, // C7: mov EA16, DATA16 _enter, // C8: enter DATA16, DATA8 - leave, // C9: leave + fleave, // C9: leave _ret_far_data16, // CA: ret far DATA16 _ret_far, // CB: ret far _int_03, // CC: int 3