--- np2/i286c/i286c_mn.c 2003/10/26 06:44:47 1.8 +++ np2/i286c/i286c_mn.c 2003/11/24 07:40:01 1.11 @@ -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); @@ -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 { @@ -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,15 +2012,24 @@ 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 { +#if 1 // 03/11/23 + UINT32 ad; + BYTE val; + I286_WORKCLOCK(3); + ad = c_calc_ea_dst[op](); + GET_PCBYTE(val) + i286_memorywrite(ad, val); +#else UINT ad; BYTE val; I286_WORKCLOCK(3); ad = c_get_ea[op](); GET_PCBYTE(val) i286_memorywrite(ad + EA_FIX, val); +#endif } } @@ -2031,15 +2040,24 @@ 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 { +#if 1 // 03/11/23 + UINT32 ad; + UINT16 val; + I286_WORKCLOCK(3); + ad = c_calc_ea_dst[op](); + GET_PCWORD(val) + i286_memorywrite_w(ad, val); +#else UINT ad; UINT16 val; I286_WORKCLOCK(3); ad = c_get_ea[op](); GET_PCWORD(val) i286_memorywrite_w(ad + EA_FIX, val); +#endif } } @@ -2073,10 +2091,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; @@ -2158,7 +2184,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 +2207,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 +2231,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 +2259,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); @@ -3075,7 +3101,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 @@ -3420,7 +3446,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