|
|
| version 1.7, 2003/10/25 13:52:24 | version 1.11, 2003/11/24 07:40:01 |
|---|---|
| Line 43 I286FN _add_ea_r8(void) { // 00: ad | Line 43 I286FN _add_ea_r8(void) { // 00: ad |
| PREPART_EA_REG8(op, src); | PREPART_EA_REG8(op, src); |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| out = reg8_b20[op]; | out = REG8_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(7); | I286_WORKCLOCK(7); |
| Line 73 I286FN _add_ea_r16(void) { // 01: a | Line 73 I286FN _add_ea_r16(void) { // 01: a |
| PREPART_EA_REG16(op, src); | PREPART_EA_REG16(op, src); |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| out = reg16_b20[op]; | out = REG16_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(7); | I286_WORKCLOCK(7); |
| Line 163 I286FN _or_ea_r8(void) { // 08: or | Line 163 I286FN _or_ea_r8(void) { // 08: or |
| PREPART_EA_REG8(op, src); | PREPART_EA_REG8(op, src); |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| out = reg8_b20[op]; | out = REG8_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(7); | I286_WORKCLOCK(7); |
| Line 190 I286FN _or_ea_r16(void) { // 09: o | Line 190 I286FN _or_ea_r16(void) { // 09: o |
| PREPART_EA_REG16(op, src); | PREPART_EA_REG16(op, src); |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| out = reg16_b20[op]; | out = REG16_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(7); | I286_WORKCLOCK(7); |
| Line 261 I286FN _adc_ea_r8(void) { // 10: ad | Line 261 I286FN _adc_ea_r8(void) { // 10: ad |
| PREPART_EA_REG8(op, src); | PREPART_EA_REG8(op, src); |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| out = reg8_b20[op]; | out = REG8_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(7); | I286_WORKCLOCK(7); |
| Line 291 I286FN _adc_ea_r16(void) { // 11: a | Line 291 I286FN _adc_ea_r16(void) { // 11: a |
| PREPART_EA_REG16(op, src); | PREPART_EA_REG16(op, src); |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| out = reg16_b20[op]; | out = REG16_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(7); | I286_WORKCLOCK(7); |
| Line 384 I286FN _sbb_ea_r8(void) { // 18: sb | Line 384 I286FN _sbb_ea_r8(void) { // 18: sb |
| PREPART_EA_REG8(op, src); | PREPART_EA_REG8(op, src); |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| out = reg8_b20[op]; | out = REG8_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(7); | I286_WORKCLOCK(7); |
| Line 414 I286FN _sbb_ea_r16(void) { // 19: s | Line 414 I286FN _sbb_ea_r16(void) { // 19: s |
| PREPART_EA_REG16(op, src); | PREPART_EA_REG16(op, src); |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| out = reg16_b20[op]; | out = REG16_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(7); | I286_WORKCLOCK(7); |
| Line 505 I286FN _and_ea_r8(void) { // 20: an | Line 505 I286FN _and_ea_r8(void) { // 20: an |
| PREPART_EA_REG8(op, src); | PREPART_EA_REG8(op, src); |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| out = reg8_b20[op]; | out = REG8_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(7); | I286_WORKCLOCK(7); |
| Line 532 I286FN _and_ea_r16(void) { // 21: a | Line 532 I286FN _and_ea_r16(void) { // 21: a |
| PREPART_EA_REG16(op, src); | PREPART_EA_REG16(op, src); |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| out = reg16_b20[op]; | out = REG16_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(7); | I286_WORKCLOCK(7); |
| Line 634 I286FN _sub_ea_r8(void) { // 28: su | Line 634 I286FN _sub_ea_r8(void) { // 28: su |
| PREPART_EA_REG8(op, src); | PREPART_EA_REG8(op, src); |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| out = reg8_b20[op]; | out = REG8_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(7); | I286_WORKCLOCK(7); |
| Line 664 I286FN _sub_ea_r16(void) { // 29: s | Line 664 I286FN _sub_ea_r16(void) { // 29: s |
| PREPART_EA_REG16(op, src); | PREPART_EA_REG16(op, src); |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| out = reg16_b20[op]; | out = REG16_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(7); | I286_WORKCLOCK(7); |
| Line 776 I286FN _xor_ea_r8(void) { // 30: xo | Line 776 I286FN _xor_ea_r8(void) { // 30: xo |
| PREPART_EA_REG8(op, src); | PREPART_EA_REG8(op, src); |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| out = reg8_b20[op]; | out = REG8_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(7); | I286_WORKCLOCK(7); |
| Line 803 I286FN _xor_ea_r16(void) { // 31: x | Line 803 I286FN _xor_ea_r16(void) { // 31: x |
| PREPART_EA_REG16(op, src); | PREPART_EA_REG16(op, src); |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| out = reg16_b20[op]; | out = REG16_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(7); | I286_WORKCLOCK(7); |
| Line 857 I286FN _xor_ax_data16(void) { // 35: | Line 857 I286FN _xor_ax_data16(void) { // 35: |
| WORD_XOR(I286_AX, src); | WORD_XOR(I286_AX, src); |
| } | } |
| I286FN _segprefix_ss(void) { // 36: cs: | I286FN _segprefix_ss(void) { // 36: ss: |
| SS_FIX = SS_BASE; | SS_FIX = SS_BASE; |
| DS_FIX = SS_BASE; | DS_FIX = SS_BASE; |
| Line 897 I286FN _cmp_ea_r8(void) { // 38: cm | Line 897 I286FN _cmp_ea_r8(void) { // 38: cm |
| PREPART_EA_REG8(op, src); | PREPART_EA_REG8(op, src); |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| dst = *(reg8_b20[op]); | dst = *(REG8_B20(op)); |
| BYTE_SUB(res, dst, src); | BYTE_SUB(res, dst, src); |
| } | } |
| else { | else { |
| Line 917 I286FN _cmp_ea_r16(void) { // 39: c | Line 917 I286FN _cmp_ea_r16(void) { // 39: c |
| PREPART_EA_REG16(op, src); | PREPART_EA_REG16(op, src); |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| dst = *(reg16_b20[op]); | dst = *(REG16_B20(op)); |
| WORD_SUB(res, dst, src); | WORD_SUB(res, dst, src); |
| } | } |
| else { | else { |
| Line 1032 I286FN _pop_ax(void) REGPOP(I286_AX, 5) | Line 1032 I286FN _pop_ax(void) REGPOP(I286_AX, 5) |
| I286FN _pop_cx(void) REGPOP(I286_CX, 5) // 59: pop cx | I286FN _pop_cx(void) REGPOP(I286_CX, 5) // 59: pop cx |
| I286FN _pop_dx(void) REGPOP(I286_DX, 5) // 5A: pop dx | I286FN _pop_dx(void) REGPOP(I286_DX, 5) // 5A: pop dx |
| I286FN _pop_bx(void) REGPOP(I286_BX, 5) // 5B: pop bx | 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_bp(void) REGPOP(I286_BP, 5) // 5D: pop bp |
| I286FN _pop_si(void) REGPOP(I286_SI, 5) // 5E: pop si | I286FN _pop_si(void) REGPOP(I286_SI, 5) // 5E: pop si |
| I286FN _pop_di(void) REGPOP(I286_DI, 5) // 5F: pop di | I286FN _pop_di(void) REGPOP(I286_DI, 5) // 5F: pop di |
| Line 1076 I286FN _bound(void) { // 62: bound | Line 1076 I286FN _bound(void) { // 62: bound |
| I286_WORKCLOCK(13); // ToDo | I286_WORKCLOCK(13); // ToDo |
| GET_PCBYTE(op); | GET_PCBYTE(op); |
| if (op < 0xc0) { | if (op < 0xc0) { |
| reg = *(reg16_b53[op]); | reg = *(REG16_B53(op)); |
| madr = c_calc_ea_dst[op](); | madr = c_calc_ea_dst[op](); |
| if (reg >= i286_memoryread_w(madr)) { | if (reg >= i286_memoryread_w(madr)) { |
| madr += 2; // ToDo | madr += 2; // ToDo |
| Line 1282 I286FN _calc_ea8_i8(void) { // 80: o | Line 1282 I286FN _calc_ea8_i8(void) { // 80: o |
| GET_PCBYTE(op) | GET_PCBYTE(op) |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(3); | I286_WORKCLOCK(3); |
| out = reg8_b20[op]; | out = REG8_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(7); | I286_WORKCLOCK(7); |
| Line 1306 I286FN _calc_ea16_i16(void) { // 81: | Line 1306 I286FN _calc_ea16_i16(void) { // 81: |
| GET_PCBYTE(op) | GET_PCBYTE(op) |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(3); | I286_WORKCLOCK(3); |
| out = reg16_b20[op]; | out = REG16_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(7); | I286_WORKCLOCK(7); |
| Line 1332 I286FN _calc_ea16_i8(void) { // 83: o | Line 1332 I286FN _calc_ea16_i8(void) { // 83: o |
| GET_PCBYTE(op) | GET_PCBYTE(op) |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(3); | I286_WORKCLOCK(3); |
| out = reg16_b20[op]; | out = REG16_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(7); | I286_WORKCLOCK(7); |
| Line 1359 I286FN _test_ea_r8(void) { // 84: te | Line 1359 I286FN _test_ea_r8(void) { // 84: te |
| PREPART_EA_REG8(op, src); | PREPART_EA_REG8(op, src); |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| out = reg8_b20[op]; | out = REG8_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(6); | I286_WORKCLOCK(6); |
| Line 1386 I286FN _test_ea_r16(void) { // 85: t | Line 1386 I286FN _test_ea_r16(void) { // 85: t |
| PREPART_EA_REG16(op, src); | PREPART_EA_REG16(op, src); |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| out = reg16_b20[op]; | out = REG16_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(7); | I286_WORKCLOCK(7); |
| Line 1412 I286FN _xchg_ea_r8(void) { // 86: xc | Line 1412 I286FN _xchg_ea_r8(void) { // 86: xc |
| PREPART_EA_REG8P(op, src); | PREPART_EA_REG8P(op, src); |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(3); | I286_WORKCLOCK(3); |
| out = reg8_b20[op]; | out = REG8_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(5); | I286_WORKCLOCK(5); |
| Line 1438 I286FN _xchg_ea_r16(void) { // 87: x | Line 1438 I286FN _xchg_ea_r16(void) { // 87: x |
| PREPART_EA_REG16P(op, src); | PREPART_EA_REG16P(op, src); |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(3); | I286_WORKCLOCK(3); |
| out = reg16_b20[op]; | out = REG16_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(5); | I286_WORKCLOCK(5); |
| Line 1463 I286FN _mov_ea_r8(void) { // 88: mov | Line 1463 I286FN _mov_ea_r8(void) { // 88: mov |
| PREPART_EA_REG8(op, src) | PREPART_EA_REG8(op, src) |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| *(reg8_b20[op]) = src; | *(REG8_B20(op)) = src; |
| } | } |
| else { | else { |
| I286_WORKCLOCK(3); | I286_WORKCLOCK(3); |
| Line 1480 I286FN _mov_ea_r16(void) { // 89: mo | Line 1480 I286FN _mov_ea_r16(void) { // 89: mo |
| PREPART_EA_REG16(op, src); | PREPART_EA_REG16(op, src); |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| *(reg16_b20[op]) = src; | *(REG16_B20(op)) = src; |
| } | } |
| else { | else { |
| I286_WORKCLOCK(3); | I286_WORKCLOCK(3); |
| Line 1517 I286FN _mov_ea_seg(void) { // 8C: mo | Line 1517 I286FN _mov_ea_seg(void) { // 8C: mo |
| tmp = *SEGMENTPTR((op >> 3) & 3); | tmp = *SEGMENTPTR((op >> 3) & 3); |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| *(reg16_b20[op]) = tmp; | *(REG16_B20(op)) = tmp; |
| } | } |
| else { | else { |
| I286_WORKCLOCK(3); | I286_WORKCLOCK(3); |
| Line 1532 I286FN _lea_r16_ea(void) { // 8D: le | Line 1532 I286FN _lea_r16_ea(void) { // 8D: le |
| I286_WORKCLOCK(3); | I286_WORKCLOCK(3); |
| GET_PCBYTE(op) | GET_PCBYTE(op) |
| if (op < 0xc0) { | if (op < 0xc0) { |
| *(reg16_b53[op]) = c_calc_lea[op](); | *(REG16_B53(op)) = c_calc_lea[op](); |
| } | } |
| else { | else { |
| INT_NUM(6, I286_SP - 2); | INT_NUM(6, I286_SP - 2); |
| Line 1549 I286FN _mov_seg_ea(void) { // 8E: mo | Line 1549 I286FN _mov_seg_ea(void) { // 8E: mo |
| GET_PCBYTE(op); | GET_PCBYTE(op); |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| tmp = *(reg16_b20[op]); | tmp = *(REG16_B20(op)); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(5); | I286_WORKCLOCK(5); |
| Line 1593 I286FN _pop_ea(void) { // 8F: pop | Line 1593 I286FN _pop_ea(void) { // 8F: pop |
| i286_memorywrite_w(c_calc_ea_dst[op](), tmp); | i286_memorywrite_w(c_calc_ea_dst[op](), tmp); |
| } | } |
| else { | else { |
| *(reg16_b20[op]) = tmp; | *(REG16_B20(op)) = tmp; |
| } | } |
| } | } |
| Line 1904 I286FN _shift_ea8_data8(void) { // C0 | Line 1904 I286FN _shift_ea8_data8(void) { // C0 |
| GET_PCBYTE(op) | GET_PCBYTE(op) |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(5); | I286_WORKCLOCK(5); |
| out = reg8_b20[op]; | out = REG8_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(8); | I286_WORKCLOCK(8); |
| Line 1932 I286FN _shift_ea16_data8(void) { // C1 | Line 1932 I286FN _shift_ea16_data8(void) { // C1 |
| GET_PCBYTE(op) | GET_PCBYTE(op) |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(5); | I286_WORKCLOCK(5); |
| out = reg16_b20[op]; | out = REG16_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(8); | I286_WORKCLOCK(8); |
| Line 1975 I286FN _les_r16_ea(void) { // C4: le | Line 1975 I286FN _les_r16_ea(void) { // C4: le |
| GET_PCBYTE(op) | GET_PCBYTE(op) |
| if (op < 0xc0) { | if (op < 0xc0) { |
| ad = c_get_ea[op](); | 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; | ad += 2; |
| I286_ES = i286_memoryread_w(ad + EA_FIX); | I286_ES = i286_memoryread_w(ad + EA_FIX); |
| ES_BASE = I286_ES << 4; | ES_BASE = I286_ES << 4; |
| Line 1994 I286FN _lds_r16_ea(void) { // C5: ld | Line 1994 I286FN _lds_r16_ea(void) { // C5: ld |
| GET_PCBYTE(op) | GET_PCBYTE(op) |
| if (op < 0xc0) { | if (op < 0xc0) { |
| ad = c_get_ea[op](); | 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; | ad += 2; |
| I286_DS = i286_memoryread_w(ad + EA_FIX); | I286_DS = i286_memoryread_w(ad + EA_FIX); |
| DS_BASE = I286_DS << 4; | DS_BASE = I286_DS << 4; |
| Line 2012 I286FN _mov_ea8_data8(void) { // C6: | Line 2012 I286FN _mov_ea8_data8(void) { // C6: |
| GET_PCBYTE(op) | GET_PCBYTE(op) |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| GET_PCBYTE(*(reg8_b53[op])) | GET_PCBYTE(*(REG8_B53(op))) |
| } | } |
| else { | 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; | UINT ad; |
| BYTE val; | BYTE val; |
| I286_WORKCLOCK(3); | I286_WORKCLOCK(3); |
| ad = c_get_ea[op](); | ad = c_get_ea[op](); |
| GET_PCBYTE(val) | GET_PCBYTE(val) |
| i286_memorywrite(ad + EA_FIX, val); | i286_memorywrite(ad + EA_FIX, val); |
| #endif | |
| } | } |
| } | } |
| Line 2031 I286FN _mov_ea16_data16(void) { // C7 | Line 2040 I286FN _mov_ea16_data16(void) { // C7 |
| GET_PCBYTE(op) | GET_PCBYTE(op) |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| GET_PCWORD(*(reg16_b53[op])) | GET_PCWORD(*(REG16_B53(op))) |
| } | } |
| else { | 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; | UINT ad; |
| UINT16 val; | UINT16 val; |
| I286_WORKCLOCK(3); | I286_WORKCLOCK(3); |
| ad = c_get_ea[op](); | ad = c_get_ea[op](); |
| GET_PCWORD(val) | GET_PCWORD(val) |
| i286_memorywrite_w(ad + EA_FIX, val); | i286_memorywrite_w(ad + EA_FIX, val); |
| #endif | |
| } | } |
| } | } |
| Line 2073 I286FN _enter(void) { // C8: enter | Line 2091 I286FN _enter(void) { // C8: enter |
| bp = I286_BP; | bp = I286_BP; |
| I286_BP = I286_SP; | I286_BP = I286_SP; |
| while(level--) { | 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); | UINT16 val = i286_memoryread_w(bp + SS_BASE); |
| i286_memorywrite_w(I286_SP + SS_BASE, val); | i286_memorywrite_w(I286_SP + SS_BASE, val); |
| bp -= 2; | bp -= 2; |
| I286_SP -= 2; | I286_SP -= 2; |
| #endif | |
| } | } |
| REGPUSH0(I286_BP) | REGPUSH0(I286_BP) |
| I286_SP -= dimsize; | I286_SP -= dimsize; |
| Line 2158 I286FN _shift_ea8_1(void) { // D0: sh | Line 2184 I286FN _shift_ea8_1(void) { // D0: sh |
| GET_PCBYTE(op) | GET_PCBYTE(op) |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| out = reg8_b20[op]; | out = REG8_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(7); | I286_WORKCLOCK(7); |
| Line 2181 I286FN _shift_ea16_1(void) { // D1: sh | Line 2207 I286FN _shift_ea16_1(void) { // D1: sh |
| GET_PCBYTE(op) | GET_PCBYTE(op) |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(2); | I286_WORKCLOCK(2); |
| out = reg16_b20[op]; | out = REG16_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(7); | I286_WORKCLOCK(7); |
| Line 2205 I286FN _shift_ea8_cl(void) { // D2: sh | Line 2231 I286FN _shift_ea8_cl(void) { // D2: sh |
| GET_PCBYTE(op) | GET_PCBYTE(op) |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(5); | I286_WORKCLOCK(5); |
| out = reg8_b20[op]; | out = REG8_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(8); | I286_WORKCLOCK(8); |
| Line 2233 I286FN _shift_ea16_cl(void) { // D3: s | Line 2259 I286FN _shift_ea16_cl(void) { // D3: s |
| GET_PCBYTE(op) | GET_PCBYTE(op) |
| if (op >= 0xc0) { | if (op >= 0xc0) { |
| I286_WORKCLOCK(5); | I286_WORKCLOCK(5); |
| out = reg16_b20[op]; | out = REG16_B20(op); |
| } | } |
| else { | else { |
| I286_WORKCLOCK(8); | I286_WORKCLOCK(8); |
| Line 3075 const I286OP i286op_repe[] = { | Line 3101 const I286OP i286op_repe[] = { |
| i286c_repe_cmpsw, // A7: repe cmpsw | i286c_repe_cmpsw, // A7: repe cmpsw |
| _test_al_data8, // A8: test al, DATA8 | _test_al_data8, // A8: test al, DATA8 |
| _test_ax_data16, // A9: test ax, DATA16 | _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_stosw, // AB: rep stosw |
| i286c_rep_lodsb, // AC: rep lodsb | i286c_rep_lodsb, // AC: rep lodsb |
| i286c_rep_lodsw, // AD: rep lodsw | i286c_rep_lodsw, // AD: rep lodsw |
| Line 3420 const I286OP i286op_repne[] = { | Line 3446 const I286OP i286op_repne[] = { |
| i286c_repne_cmpsw, // A7: repne cmpsw | i286c_repne_cmpsw, // A7: repne cmpsw |
| _test_al_data8, // A8: test al, DATA8 | _test_al_data8, // A8: test al, DATA8 |
| _test_ax_data16, // A9: test ax, DATA16 | _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_stosw, // AB: rep stosw |
| i286c_rep_lodsb, // AC: rep lodsb | i286c_rep_lodsb, // AC: rep lodsb |
| i286c_rep_lodsw, // AD: rep lodsw | i286c_rep_lodsw, // AD: rep lodsw |