--- np2/i286c/i286c_0f.c 2003/10/16 17:57:43 1.1.1.1 +++ np2/i286c/i286c_0f.c 2003/10/17 11:10:02 1.3 @@ -6,95 +6,97 @@ #include "nevent.h" -I286_0F _sgdt(DWORD op) { +I286_0F _sgdt(UINT op) { I286_CLOCK(11) if (op < 0xc0) { UINT16 ad = c_get_ea[op](); - i286_memorywrite_w(ad + EA_FIX, GDTR.limit); + i286_memorywrite_w(ad + EA_FIX, i286reg.GDTR.limit); ad += 2; - i286_memorywrite_w(ad + EA_FIX, GDTR.base); + i286_memorywrite_w(ad + EA_FIX, i286reg.GDTR.base); ad += 2; - i286_memorywrite_w(ad + EA_FIX, (UINT16)(0xff00 + GDTR.base24)); + i286_memorywrite_w(ad + EA_FIX, + (UINT16)(0xff00 + i286reg.GDTR.base24)); } else { INT_NUM(6, I286_IP - 2); } } -I286_0F _sidt(DWORD op) { +I286_0F _sidt(UINT op) { I286_CLOCK(12) if (op < 0xc0) { UINT16 ad = c_get_ea[op](); - i286_memorywrite_w(ad + EA_FIX, IDTR.limit); + i286_memorywrite_w(ad + EA_FIX, i286reg.IDTR.limit); ad += 2; - i286_memorywrite_w(ad + EA_FIX, IDTR.base); + i286_memorywrite_w(ad + EA_FIX, i286reg.IDTR.base); ad += 2; - i286_memorywrite_w(ad + EA_FIX, (UINT16)(0xff00 + IDTR.base24)); + i286_memorywrite_w(ad + EA_FIX, + (UINT16)(0xff00 + i286reg.IDTR.base24)); } else { INT_NUM(6, I286_IP - 2); } } -I286_0F _lgdt(DWORD op) { +I286_0F _lgdt(UINT op) { I286_CLOCK(11) if (op < 0xc0) { - WORD ad = c_get_ea[op](); - GDTR.limit = i286_memoryread_w(ad + EA_FIX); + UINT16 ad = c_get_ea[op](); + i286reg.GDTR.limit = i286_memoryread_w(ad + EA_FIX); ad += 2; - GDTR.base = i286_memoryread_w(ad + EA_FIX); + i286reg.GDTR.base = i286_memoryread_w(ad + EA_FIX); ad += 2; - GDTR.base24 = i286_memoryread(ad + EA_FIX); + i286reg.GDTR.base24 = i286_memoryread(ad + EA_FIX); ad++; - GDTR.reserved = i286_memoryread(ad + EA_FIX); + i286reg.GDTR.reserved = i286_memoryread(ad + EA_FIX); } else { INT_NUM(6, I286_IP - 2); } } -I286_0F _lidt(DWORD op) { +I286_0F _lidt(UINT op) { I286_CLOCK(11) if (op < 0xc0) { - WORD ad = c_get_ea[op](); - IDTR.limit = i286_memoryread_w(ad + EA_FIX); + UINT16 ad = c_get_ea[op](); + i286reg.IDTR.limit = i286_memoryread_w(ad + EA_FIX); ad += 2; - IDTR.base = i286_memoryread_w(ad + EA_FIX); + i286reg.IDTR.base = i286_memoryread_w(ad + EA_FIX); ad += 2; - IDTR.base24 = i286_memoryread(ad + EA_FIX); + i286reg.IDTR.base24 = i286_memoryread(ad + EA_FIX); ad++; - IDTR.reserved = i286_memoryread(ad + EA_FIX); + i286reg.IDTR.reserved = i286_memoryread(ad + EA_FIX); } else { INT_NUM(6, I286_IP - 2); } } -I286_0F _smsw(DWORD op) { +I286_0F _smsw(UINT op) { if (op >= 0xc0) { I286_CLOCK(3) - *(reg16_b20[op]) = MSW; + *(reg16_b20[op]) = i286reg.MSW; } else { I286_CLOCK(6) - i286_memorywrite_w(c_calc_ea_dst[op](), MSW); + i286_memorywrite_w(c_calc_ea_dst[op](), i286reg.MSW); } } -I286_0F _lmsw(DWORD op) { +I286_0F _lmsw(UINT op) { if (op >= 0xc0) { I286_CLOCK(2) - MSW = *(reg16_b20[op]); + i286reg.MSW = *(reg16_b20[op]); } else { I286_CLOCK(3) - MSW = i286_memoryread_w(c_calc_ea_dst[op]()); + i286reg.MSW = i286_memoryread_w(c_calc_ea_dst[op]()); } } @@ -110,7 +112,7 @@ I286_0F _loadall286(void) { UINT16 tmp; I286_CLOCK(195); - MSW = LOADINTELWORD(mem + 0x804); + i286reg.MSW = LOADINTELWORD(mem + 0x804); tmp = LOADINTELWORD(mem + 0x818); I286_OV = tmp & O_FLAG; I286_FLAG = tmp & (0xfff ^ O_FLAG); @@ -139,8 +141,9 @@ I286_0F _loadall286(void) { I286EXT i286c_cts(void) { - WORD ip; - DWORD op, op2; + UINT16 ip; + UINT op; + UINT op2; ip = I286_IP; GET_PCBYTE(op);