Diff for /np2/i286c/i286c_f6.c between versions 1.5 and 1.11

version 1.5, 2003/10/21 11:22:05 version 1.11, 2003/12/08 00:55:31
Line 1 Line 1
 #include        "compiler.h"  #include        "compiler.h"
 #include        "i286.h"  #include        "cpucore.h"
 #include        "i286c.h"  #include        "i286c.h"
 #include        "memory.h"  #include        "memory.h"
 #include        "i286c.mcr"  #include        "i286c.mcr"
Line 14  I286_F6 _test_ea8_data8(UINT op) { Line 14  I286_F6 _test_ea8_data8(UINT op) {
   
         if (op >= 0xc0) {          if (op >= 0xc0) {
                 I286_WORKCLOCK(2);                  I286_WORKCLOCK(2);
                 dst = *(reg8_b20[op]);                  dst = *(REG8_B20(op));
         }          }
         else {          else {
                 I286_WORKCLOCK(6);                  I286_WORKCLOCK(6);
                 dst = i286_memoryread(c_calc_ea_dst[op]());                  dst = i286_memoryread(CALC_EA(op));
         }          }
         GET_PCBYTE(src)          GET_PCBYTE(src)
         ANDBYTE(dst, src)          ANDBYTE(dst, src)
Line 30  I286_F6 _not_ea8(UINT op) { Line 30  I286_F6 _not_ea8(UINT op) {
   
         if (op >= 0xc0) {          if (op >= 0xc0) {
                 I286_WORKCLOCK(2);                  I286_WORKCLOCK(2);
                 *(reg8_b20[op]) ^= 0xff;                  *(REG8_B20(op)) ^= 0xff;
         }          }
         else {          else {
                 I286_WORKCLOCK(7);                  I286_WORKCLOCK(7);
                 madr = c_calc_ea_dst[op]();                  madr = CALC_EA(op);
                 if (madr >= I286_MEMWRITEMAX) {                  if (madr >= I286_MEMWRITEMAX) {
                         BYTE value = i286_memoryread(madr);                          REG8 value = i286_memoryread(madr);
                         value = ~value;                          value ^= 0xff;
                         i286_memorywrite(madr, value);                          i286_memorywrite(madr, value);
                         return;                          return;
                 }                  }
Line 54  I286_F6 _neg_ea8(UINT op) { Line 54  I286_F6 _neg_ea8(UINT 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);
                 madr = c_calc_ea_dst[op]();                  madr = CALC_EA(op);
                 if (madr >= I286_MEMWRITEMAX) {                  if (madr >= I286_MEMWRITEMAX) {
                         src = i286_memoryread(madr);                          src = i286_memoryread(madr);
                         BYTE_NEG(dst, src)                          NEGBYTE(dst, src)
                         i286_memorywrite(madr, (BYTE)dst);                          i286_memorywrite(madr, (BYTE)dst);
                         return;                          return;
                 }                  }
                 out = mem + madr;                  out = mem + madr;
         }          }
         src = *out;          src = *out;
         BYTE_NEG(dst, src)          NEGBYTE(dst, src)
         *out = (BYTE)dst;          *out = (BYTE)dst;
 }  }
   
Line 79  I286_F6 _mul_ea8(UINT op) { Line 79  I286_F6 _mul_ea8(UINT op) {
   
         if (op >= 0xc0) {          if (op >= 0xc0) {
                 I286_WORKCLOCK(13);                  I286_WORKCLOCK(13);
                 src = *(reg8_b20[op]);                  src = *(REG8_B20(op));
         }          }
         else {          else {
                 I286_WORKCLOCK(16);                  I286_WORKCLOCK(16);
                 src = i286_memoryread(c_calc_ea_dst[op]());                  src = i286_memoryread(CALC_EA(op));
         }          }
         BYTE_MUL(res, I286_AL, src)          BYTE_MUL(res, I286_AL, src)
         I286_AX = (UINT16)res;          I286_AX = (UINT16)res;
Line 96  I286_F6 _imul_ea8(UINT op) { Line 96  I286_F6 _imul_ea8(UINT op) {
   
         if (op >= 0xc0) {          if (op >= 0xc0) {
                 I286_WORKCLOCK(13);                  I286_WORKCLOCK(13);
                 src = *(reg8_b20[op]);                  src = *(REG8_B20(op));
         }          }
         else {          else {
                 I286_WORKCLOCK(16);                  I286_WORKCLOCK(16);
                 src = i286_memoryread(c_calc_ea_dst[op]());                  src = i286_memoryread(CALC_EA(op));
         }          }
         BYTE_IMUL(res, I286_AL, src)          BYTE_IMUL(res, I286_AL, src)
         I286_AX = (UINT16)res;          I286_AX = (UINT16)res;
Line 114  I286_F6 _div_ea8(UINT op) { Line 114  I286_F6 _div_ea8(UINT op) {
   
         ip = I286_IP;          ip = I286_IP;
         if (op >= 0xc0) {          if (op >= 0xc0) {
                 I286_WORKCLOCK(2);                  I286_WORKCLOCK(14);
                 src = *(reg8_b20[op]);                  src = *(REG8_B20(op));
         }          }
         else {          else {
                 I286_WORKCLOCK(7);                  I286_WORKCLOCK(17);
                 src = i286_memoryread(c_calc_ea_dst[op]());                  src = i286_memoryread(CALC_EA(op));
         }          }
         tmp = I286_AX;          tmp = I286_AX;
         if (tmp < ((UINT16)src << 8)) {          if ((src) && (tmp < ((UINT16)src << 8))) {
                 I286_AL = tmp / src;                  I286_AL = tmp / src;
                 I286_AH = tmp % src;                  I286_AH = tmp % src;
         }          }
Line 140  I286_F6 _idiv_ea8(UINT op) { Line 140  I286_F6 _idiv_ea8(UINT op) {
         ip = I286_IP;          ip = I286_IP;
         if (op >= 0xc0) {          if (op >= 0xc0) {
                 I286_WORKCLOCK(17);                  I286_WORKCLOCK(17);
                 src = *(reg8_b20[op]);                  src = *(REG8_B20(op));
         }          }
         else {          else {
                 I286_WORKCLOCK(25);                  I286_WORKCLOCK(20);
                 src = i286_memoryread(c_calc_ea_dst[op]());                  src = i286_memoryread(CALC_EA(op));
         }          }
         tmp = (SINT16)I286_AX;          tmp = (SINT16)I286_AX;
         if (src) {          if (src) {
Line 166  I286_F6 _test_ea16_data16(UINT op) { Line 166  I286_F6 _test_ea16_data16(UINT op) {
   
         if (op >= 0xc0) {          if (op >= 0xc0) {
                 I286_WORKCLOCK(2);                  I286_WORKCLOCK(2);
                 dst = *(reg16_b20[op]);                  dst = *(REG16_B20(op));
         }          }
         else {          else {
                 I286_WORKCLOCK(6);                  I286_WORKCLOCK(6);
                 dst = i286_memoryread_w(c_calc_ea_dst[op]());                  dst = i286_memoryread_w(CALC_EA(op));
         }          }
         GET_PCWORD(src)          GET_PCWORD(src)
         ANDWORD(dst, src)          ANDWORD(dst, src)
Line 182  I286_F6 _not_ea16(UINT op) { Line 182  I286_F6 _not_ea16(UINT op) {
   
         if (op >= 0xc0) {          if (op >= 0xc0) {
                 I286_WORKCLOCK(2);                  I286_WORKCLOCK(2);
                 *(reg16_b20[op]) ^= 0xffff;                  *(REG16_B20(op)) ^= 0xffff;
         }          }
         else {          else {
                 I286_WORKCLOCK(7);                  I286_WORKCLOCK(7);
                 madr = c_calc_ea_dst[op]();                  madr = CALC_EA(op);
                 if (!(INHIBIT_WORDP(madr))) {                  if (!(INHIBIT_WORDP(madr))) {
                         *(mem + madr) ^= 0xffff;                          *(mem + madr) ^= 0xffff;
                 }                  }
                 else {                  else {
                         UINT16 value = i286_memoryread_w(madr);                          REG16 value = i286_memoryread_w(madr);
                         value = ~value;                          value = ~value;
                         i286_memorywrite_w(madr, value);                          i286_memorywrite_w(madr, value);
                 }                  }
Line 207  I286_F6 _neg_ea16(UINT op) { Line 207  I286_F6 _neg_ea16(UINT 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);
                 madr = c_calc_ea_dst[op]();                  madr = CALC_EA(op);
                 if (INHIBIT_WORDP(madr)) {                  if (INHIBIT_WORDP(madr)) {
                         src = i286_memoryread_w(madr);                          src = i286_memoryread_w(madr);
                         WORD_NEG(dst, src)                          NEGWORD(dst, src)
                         i286_memorywrite_w(madr, (UINT16)dst);                          i286_memorywrite_w(madr, (REG16)dst);
                         return;                          return;
                 }                  }
                 out = (UINT16 *)(mem + madr);                  out = (UINT16 *)(mem + madr);
         }          }
         src = *out;          src = *out;
         WORD_NEG(dst, src)          NEGWORD(dst, src)
         *out = (UINT16)dst;          *out = (UINT16)dst;
 }  }
   
Line 232  I286_F6 _mul_ea16(UINT op) { Line 232  I286_F6 _mul_ea16(UINT op) {
   
         if (op >= 0xc0) {          if (op >= 0xc0) {
                 I286_WORKCLOCK(21);                  I286_WORKCLOCK(21);
                 src = *(reg16_b20[op]);                  src = *(REG16_B20(op));
         }          }
         else {          else {
                 I286_WORKCLOCK(24);                  I286_WORKCLOCK(24);
                 src = i286_memoryread_w(c_calc_ea_dst[op]());                  src = i286_memoryread_w(CALC_EA(op));
         }          }
         WORD_MUL(res, I286_AX, src)          WORD_MUL(res, I286_AX, src)
         I286_AX = (UINT16)res;          I286_AX = (UINT16)res;
Line 250  I286_F6 _imul_ea16(UINT op) { Line 250  I286_F6 _imul_ea16(UINT op) {
   
         if (op >= 0xc0) {          if (op >= 0xc0) {
                 I286_WORKCLOCK(21);                  I286_WORKCLOCK(21);
                 src = *(reg16_b20[op]);                  src = *(REG16_B20(op));
         }          }
         else {          else {
                 I286_WORKCLOCK(24);                  I286_WORKCLOCK(24);
                 src = i286_memoryread_w(c_calc_ea_dst[op]());                  src = i286_memoryread_w(CALC_EA(op));
         }          }
         WORD_IMUL(res, I286_AX, src)          WORD_IMUL(res, I286_AX, src)
         I286_AX = (UINT16)res;          I286_AX = (UINT16)res;
Line 269  I286_F6 _div_ea16(UINT op) { Line 269  I286_F6 _div_ea16(UINT op) {
   
         ip = I286_IP;          ip = I286_IP;
         if (op >= 0xc0) {          if (op >= 0xc0) {
                 I286_WORKCLOCK(17);                  I286_WORKCLOCK(22);
                 src = *(reg16_b20[op]);                  src = *(REG16_B20(op));
         }          }
         else {          else {
                 I286_WORKCLOCK(25);                  I286_WORKCLOCK(25);
                 src = i286_memoryread_w(c_calc_ea_dst[op]());                  src = i286_memoryread_w(CALC_EA(op));
         }          }
         tmp = (I286_DX << 16) + I286_AX;          tmp = (I286_DX << 16) + I286_AX;
         if (tmp < (src << 16)) {          if ((src) && (tmp < (src << 16))) {
                 I286_AX = (SINT16)(tmp / src);                  I286_AX = (SINT16)(tmp / src);
                 I286_DX = (SINT16)(tmp % src);                  I286_DX = (SINT16)(tmp % src);
         }          }
Line 295  I286_F6 _idiv_ea16(UINT op) { Line 295  I286_F6 _idiv_ea16(UINT op) {
   
         ip = I286_IP;          ip = I286_IP;
         if (op >= 0xc0) {          if (op >= 0xc0) {
                 I286_WORKCLOCK(17);                  I286_WORKCLOCK(25);
                 src = *(reg16_b20[op]);                  src = *(REG16_B20(op));
         }          }
         else {          else {
                 I286_WORKCLOCK(25);                  I286_WORKCLOCK(28);
                 src = i286_memoryread_w(c_calc_ea_dst[op]());                  src = i286_memoryread_w(CALC_EA(op));
         }          }
         tmp = (SINT32)((I286_DX << 16) + I286_AX);          tmp = (SINT32)((I286_DX << 16) + I286_AX);
         if (src) {          if (src) {

Removed from v.1.5  
changed lines
  Added in v.1.11


RetroPC.NET-CVS <cvs@retropc.net>