Diff for /np2/i286c/i286c_0f.c between versions 1.3 and 1.9

version 1.3, 2003/10/17 11:10:02 version 1.9, 2003/11/29 00:36:00
Line 1 Line 1
 #include        "compiler.h"  #include        "compiler.h"
 #include        "i286.h"  #include        "i286.h"
 #include        "i286c.h"  #include        "i286c.h"
 #include        "i286c.mcr"  
 #include        "memory.h"  #include        "memory.h"
 #include        "nevent.h"  #include        "i286c.mcr"
   
   
 I286_0F _sgdt(UINT op) {  I286_0F _sgdt(UINT op) {
   
         I286_CLOCK(11)          UINT32  seg;
           UINT    ad;
   
           I286_WORKCLOCK(11);
         if (op < 0xc0) {          if (op < 0xc0) {
                 UINT16 ad = c_get_ea[op]();                  ad = GET_EA(op, &seg);
                 i286_memorywrite_w(ad + EA_FIX, i286reg.GDTR.limit);                  i286_memorywrite_w(seg + ad, i286reg.GDTR.limit);
                 ad += 2;                  i286_memorywrite_w(seg + LOW16(ad + 2), i286reg.GDTR.base);
                 i286_memorywrite_w(ad + EA_FIX, i286reg.GDTR.base);                  i286_memorywrite_w(seg + LOW16(ad + 4),
                 ad += 2;                                                                          (REG16)(0xff00 + i286reg.GDTR.base24));
                 i286_memorywrite_w(ad + EA_FIX,  
                                                                         (UINT16)(0xff00 + i286reg.GDTR.base24));  
         }          }
         else {          else {
                 INT_NUM(6, I286_IP - 2);                  INT_NUM(6, I286_IP - 2);
Line 25  I286_0F _sgdt(UINT op) { Line 25  I286_0F _sgdt(UINT op) {
   
 I286_0F _sidt(UINT op) {  I286_0F _sidt(UINT op) {
   
         I286_CLOCK(12)          UINT32  seg;
           UINT    ad;
   
           I286_WORKCLOCK(12);
         if (op < 0xc0) {          if (op < 0xc0) {
                 UINT16 ad = c_get_ea[op]();                  ad = GET_EA(op, &seg);
                 i286_memorywrite_w(ad + EA_FIX, i286reg.IDTR.limit);                  i286_memorywrite_w(seg + ad, i286reg.IDTR.limit);
                 ad += 2;                  i286_memorywrite_w(seg + LOW16(ad + 2), i286reg.IDTR.base);
                 i286_memorywrite_w(ad + EA_FIX, i286reg.IDTR.base);                  i286_memorywrite_w(seg + LOW16(ad + 4),
                 ad += 2;                                                                          (REG16)(0xff00 + i286reg.IDTR.base24));
                 i286_memorywrite_w(ad + EA_FIX,  
                                                                         (UINT16)(0xff00 + i286reg.IDTR.base24));  
         }          }
         else {          else {
                 INT_NUM(6, I286_IP - 2);                  INT_NUM(6, I286_IP - 2);
Line 42  I286_0F _sidt(UINT op) { Line 43  I286_0F _sidt(UINT op) {
   
 I286_0F _lgdt(UINT op) {  I286_0F _lgdt(UINT op) {
   
         I286_CLOCK(11)          UINT32  seg;
           UINT    ad;
   
           I286_WORKCLOCK(11);
         if (op < 0xc0) {          if (op < 0xc0) {
                 UINT16 ad = c_get_ea[op]();                  ad = GET_EA(op, &seg);
                 i286reg.GDTR.limit = i286_memoryread_w(ad + EA_FIX);                  i286reg.GDTR.limit = i286_memoryread_w(seg + ad);
                 ad += 2;                  i286reg.GDTR.base = i286_memoryread_w(seg + LOW16(ad + 2));
                 i286reg.GDTR.base = i286_memoryread_w(ad + EA_FIX);                  i286reg.GDTR.base24 = i286_memoryread(seg + LOW16(ad + 4));
                 ad += 2;                  i286reg.GDTR.reserved = i286_memoryread(seg + LOW16(ad + 5));
                 i286reg.GDTR.base24 = i286_memoryread(ad + EA_FIX);  
                 ad++;  
                 i286reg.GDTR.reserved = i286_memoryread(ad + EA_FIX);  
         }          }
         else {          else {
                 INT_NUM(6, I286_IP - 2);                  INT_NUM(6, I286_IP - 2);
Line 60  I286_0F _lgdt(UINT op) { Line 61  I286_0F _lgdt(UINT op) {
   
 I286_0F _lidt(UINT op) {  I286_0F _lidt(UINT op) {
   
         I286_CLOCK(11)          UINT32  seg;
           UINT    ad;
   
           I286_WORKCLOCK(11);
         if (op < 0xc0) {          if (op < 0xc0) {
                 UINT16 ad = c_get_ea[op]();                  ad = GET_EA(op, &seg);
                 i286reg.IDTR.limit = i286_memoryread_w(ad + EA_FIX);                  i286reg.IDTR.limit = i286_memoryread_w(seg + ad);
                 ad += 2;                  i286reg.IDTR.base = i286_memoryread_w(seg + LOW16(ad + 2));
                 i286reg.IDTR.base = i286_memoryread_w(ad + EA_FIX);                  i286reg.IDTR.base24 = i286_memoryread(seg + LOW16(ad + 4));
                 ad += 2;                  i286reg.IDTR.reserved = i286_memoryread(seg + LOW16(ad + 5));
                 i286reg.IDTR.base24 = i286_memoryread(ad + EA_FIX);  
                 ad++;  
                 i286reg.IDTR.reserved = i286_memoryread(ad + EA_FIX);  
         }          }
         else {          else {
                 INT_NUM(6, I286_IP - 2);                  INT_NUM(6, I286_IP - 2);
Line 79  I286_0F _lidt(UINT op) { Line 80  I286_0F _lidt(UINT op) {
 I286_0F _smsw(UINT op) {  I286_0F _smsw(UINT op) {
   
         if (op >= 0xc0) {          if (op >= 0xc0) {
                 I286_CLOCK(3)                  I286_WORKCLOCK(3);
                 *(reg16_b20[op]) = i286reg.MSW;                  *(REG16_B20(op)) = i286reg.MSW;
         }          }
         else {          else {
                 I286_CLOCK(6)                  I286_WORKCLOCK(6);
                 i286_memorywrite_w(c_calc_ea_dst[op](), i286reg.MSW);                  i286_memorywrite_w(CALC_EA(op), i286reg.MSW);
         }          }
 }  }
   
 I286_0F _lmsw(UINT op) {  I286_0F _lmsw(UINT op) {
   
         if (op >= 0xc0) {          if (op >= 0xc0) {
                 I286_CLOCK(2)                  I286_WORKCLOCK(2);
                 i286reg.MSW = *(reg16_b20[op]);                  i286reg.MSW = *(REG16_B20(op));
         }          }
         else {          else {
                 I286_CLOCK(3)                  I286_WORKCLOCK(3);
                 i286reg.MSW = i286_memoryread_w(c_calc_ea_dst[op]());                  i286reg.MSW = i286_memoryread_w(CALC_EA(op));
         }          }
 }  }
   
Line 111  I286_0F _loadall286(void) { Line 112  I286_0F _loadall286(void) {
   
         UINT16  tmp;          UINT16  tmp;
   
         I286_CLOCK(195);          I286_WORKCLOCK(195);
         i286reg.MSW = LOADINTELWORD(mem + 0x804);          i286reg.MSW = LOADINTELWORD(mem + 0x804);
         tmp = LOADINTELWORD(mem + 0x818);          tmp = LOADINTELWORD(mem + 0x818);
         I286_OV = tmp & O_FLAG;          I286_OV = tmp & O_FLAG;
Line 156  I286EXT i286c_cts(void) { Line 157  I286EXT i286c_cts(void) {
                 _loadall286();                  _loadall286();
         }          }
         else {          else {
                 I286_CLOCK(20)                  I286_WORKCLOCK(20);
                 INT_NUM(6, ip - 1);                  INT_NUM(6, ip - 1);
         }          }
 }  }

Removed from v.1.3  
changed lines
  Added in v.1.9


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