Diff for /np2/i286c/i286c_mn.c between versions 1.27 and 1.33

version 1.27, 2003/12/26 02:02:09 version 1.33, 2004/02/18 18:29:29
Line 151  I286FN _pop_es(void) {       // 07: pop  Line 151  I286FN _pop_es(void) {       // 07: pop 
   
         REGPOP(tmp, 5)          REGPOP(tmp, 5)
         I286_ES = tmp;          I286_ES = tmp;
         if (!(I286_MSW & MSW_PE)) {          ES_BASE = SEGSELECT(tmp);
                 ES_BASE = tmp << 4;  
                 NEXT_OPCODE  
         }  
         else {  
                 ES_BASE = i286c_selector(tmp);  
         }  
 }  }
   
 I286FN _or_ea_r8(void) {                                                // 08: or EA, REG8  I286FN _or_ea_r8(void) {                                                // 08: or EA, REG8
Line 391  I286FN _push_ss(void) {       // 16: pus Line 385  I286FN _push_ss(void) {       // 16: pus
 I286FN _pop_ss(void) {                                                  // 17: pop ss  I286FN _pop_ss(void) {                                                  // 17: pop ss
   
         UINT    tmp;          UINT    tmp;
         UINT32  base;  
   
         REGPOP(tmp, 5)          REGPOP(tmp, 5)
         I286_SS = tmp;          I286_SS = tmp;
         if (!(I286_MSW & MSW_PE)) {          SS_BASE = SEGSELECT(tmp);
                 SS_BASE = tmp << 4;          SS_FIX = SS_BASE;
                 SS_FIX = tmp << 4;          NEXT_OPCODE
                 NEXT_OPCODE  
         }  
         else {  
                 base = i286c_selector(tmp);  
                 SS_BASE = base;  
                 SS_FIX = base;  
                 NEXT_OPCODE  
         }  
 }  }
   
 I286FN _sbb_ea_r8(void) {                                               // 18: sbb EA, REG8  I286FN _sbb_ea_r8(void) {                                               // 18: sbb EA, REG8
Line 526  I286FN _push_ds(void) {       // 1e: pus Line 511  I286FN _push_ds(void) {       // 1e: pus
 I286FN _pop_ds(void) {                                                  // 1f: pop ds  I286FN _pop_ds(void) {                                                  // 1f: pop ds
   
         UINT    tmp;          UINT    tmp;
         UINT32  base;  
   
         REGPOP(tmp, 5)          REGPOP(tmp, 5)
         I286_DS = tmp;          I286_DS = tmp;
         if (!(I286_MSW & MSW_PE)) {          DS_BASE = SEGSELECT(tmp);
                 DS_BASE = tmp << 4;          DS_FIX = DS_BASE;
                 DS_FIX = tmp << 4;  
                 NEXT_OPCODE  
         }  
         else {  
                 base = i286c_selector(tmp);  
                 DS_BASE = base;  
                 DS_FIX = base;  
                 NEXT_OPCODE  
         }  
 }  }
   
 I286FN _and_ea_r8(void) {                                               // 20: and EA, REG8  I286FN _and_ea_r8(void) {                                               // 20: and EA, REG8
Line 1705  I286FN _mov_seg_ea(void) {     // 8E: mo Line 1680  I286FN _mov_seg_ea(void) {     // 8E: mo
                 I286_WORKCLOCK(5);                  I286_WORKCLOCK(5);
                 tmp = i286_memoryread_w(CALC_EA(op));                  tmp = i286_memoryread_w(CALC_EA(op));
         }          }
         if (!(I286_MSW & MSW_PE)) {          base = SEGSELECT(tmp);
                 base = tmp << 4;  
         }  
         else {  
                 base = i286c_selector(tmp);  
         }  
   
         switch(op & 0x18) {          switch(op & 0x18) {
                 case 0x00:                      // es                  case 0x00:                      // es
                         I286_ES = (UINT16)tmp;                          I286_ES = (UINT16)tmp;
Line 1835  I286FN _call_far(void) {     // 9A: call Line 1804  I286FN _call_far(void) {     // 9A: call
         REGPUSH0(I286_CS)          REGPUSH0(I286_CS)
         GET_PCWORD(newip)          GET_PCWORD(newip)
         GET_PCWORD(I286_CS)          GET_PCWORD(I286_CS)
         CS_BASE = I286_CS << 4;          CS_BASE = SEGSELECT(I286_CS);
         REGPUSH0(I286_IP)          REGPUSH0(I286_IP)
         I286_IP = newip;          I286_IP = newip;
 }  }
Line 2143  I286FN _les_r16_ea(void) {     // C4: le Line 2112  I286FN _les_r16_ea(void) {     // C4: le
                 ad = GET_EA(op, &seg);                  ad = GET_EA(op, &seg);
                 *(REG16_B53(op)) = i286_memoryread_w(seg + ad);                  *(REG16_B53(op)) = i286_memoryread_w(seg + ad);
                 I286_ES = i286_memoryread_w(seg + LOW16(ad + 2));                  I286_ES = i286_memoryread_w(seg + LOW16(ad + 2));
                 ES_BASE = I286_ES << 4;                  ES_BASE = SEGSELECT(I286_ES);
         }          }
         else {          else {
                 INT_NUM(6, I286_IP - 2);                  INT_NUM(6, I286_IP - 2);
Line 2162  I286FN _lds_r16_ea(void) {     // C5: ld Line 2131  I286FN _lds_r16_ea(void) {     // C5: ld
                 ad = GET_EA(op, &seg);                  ad = GET_EA(op, &seg);
                 *(REG16_B53(op)) = i286_memoryread_w(seg + ad);                  *(REG16_B53(op)) = i286_memoryread_w(seg + ad);
                 I286_DS = i286_memoryread_w(seg + LOW16(ad + 2));                  I286_DS = i286_memoryread_w(seg + LOW16(ad + 2));
                 DS_BASE = I286_DS << 4;                  DS_BASE = SEGSELECT(I286_DS);
                 DS_FIX = DS_BASE;                  DS_FIX = DS_BASE;
         }          }
         else {          else {
Line 2273  I286FN _ret_far_data16(void) {    // CA: Line 2242  I286FN _ret_far_data16(void) {    // CA:
         REGPOP0(I286_IP)          REGPOP0(I286_IP)
         REGPOP0(I286_CS)          REGPOP0(I286_CS)
         I286_SP += ad;          I286_SP += ad;
         CS_BASE = I286_CS << 4;          CS_BASE = SEGSELECT(I286_CS);
 }  }
   
 I286FN _ret_far(void) {                                         // CB:  ret far  I286FN _ret_far(void) {                                         // CB:  ret far
Line 2281  I286FN _ret_far(void) {      // CB: ret  Line 2250  I286FN _ret_far(void) {      // CB: ret 
         I286_WORKCLOCK(15);          I286_WORKCLOCK(15);
         REGPOP0(I286_IP)          REGPOP0(I286_IP)
         REGPOP0(I286_CS)          REGPOP0(I286_CS)
         CS_BASE = I286_CS << 4;          CS_BASE = SEGSELECT(I286_CS);
 }  }
   
 I286FN _int_03(void) {                                          // CC:  int             3  I286FN _int_03(void) {                                          // CC:  int             3
Line 2311  I286FN _iret(void) {      // CF: iret Line 2280  I286FN _iret(void) {      // CF: iret
   
         UINT    flag;          UINT    flag;
   
         extirq_pop();  
         REGPOP0(I286_IP)          REGPOP0(I286_IP)
         REGPOP0(I286_CS)          REGPOP0(I286_CS)
         REGPOP0(flag)          REGPOP0(flag)
Line 2319  I286FN _iret(void) {      // CF: iret Line 2287  I286FN _iret(void) {      // CF: iret
         I286_FLAG = flag & (0xfff ^ O_FLAG);          I286_FLAG = flag & (0xfff ^ O_FLAG);
         I286_TRAP = ((flag & 0x300) == 0x300);          I286_TRAP = ((flag & 0x300) == 0x300);
         CS_BASE = I286_CS << 4;          CS_BASE = I286_CS << 4;
   //      CS_BASE = SEGSELECT(I286_CS);
         I286_WORKCLOCK(31);          I286_WORKCLOCK(31);
 #if defined(INTR_FAST)  #if defined(INTR_FAST)
         if ((I286_TRAP) || ((flag & I_FLAG) && (PICEXISTINTR))) {          if ((I286_TRAP) || ((flag & I_FLAG) && (PICEXISTINTR))) {
Line 2572  I286FN _jmp_far(void) {      // EA: jmp  Line 2541  I286FN _jmp_far(void) {      // EA: jmp 
         I286_WORKCLOCK(11);          I286_WORKCLOCK(11);
         GET_PCWORD(ad);          GET_PCWORD(ad);
         GET_PCWORD(I286_CS);          GET_PCWORD(I286_CS);
         CS_BASE = I286_CS << 4;  
         I286_IP = ad;          I286_IP = ad;
           CS_BASE = SEGSELECT(I286_CS);
 }  }
   
 I286FN _jmp_short(void) {                                       // EB:  jmp short  I286FN _jmp_short(void) {                                       // EB:  jmp short

Removed from v.1.27  
changed lines
  Added in v.1.33


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