2016-06-26 00:34:39 +02:00
|
|
|
static int opINT3(uint32_t fetchdat)
|
|
|
|
|
{
|
2016-12-23 03:16:24 +01:00
|
|
|
int cycles_old = cycles;
|
2016-06-26 00:34:39 +02:00
|
|
|
if ((cr0 & 1) && (eflags & VM_FLAG) && (IOPL != 3))
|
|
|
|
|
{
|
|
|
|
|
x86gpf(NULL,0);
|
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
x86_int_sw(3);
|
|
|
|
|
CLOCK_CYCLES((is486) ? 44 : 59);
|
2016-12-23 03:16:24 +01:00
|
|
|
PREFETCH_RUN(cycles_old-cycles, 1, -1, 0,0,0,0, 0);
|
2016-06-26 00:34:39 +02:00
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static int opINT(uint32_t fetchdat)
|
|
|
|
|
{
|
2016-12-23 03:16:24 +01:00
|
|
|
int cycles_old = cycles;
|
2016-06-26 00:34:39 +02:00
|
|
|
uint8_t temp;
|
|
|
|
|
|
|
|
|
|
/*if (msw&1) pclog("INT %i %i %i\n",cr0&1,eflags&VM_FLAG,IOPL);*/
|
|
|
|
|
if ((cr0 & 1) && (eflags & VM_FLAG) && (IOPL != 3))
|
|
|
|
|
{
|
|
|
|
|
x86gpf(NULL,0);
|
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
temp = getbytef();
|
|
|
|
|
// /*if (temp == 0x10 && AH == 0xe) */pclog("INT %02X : %04X %04X %04X %04X %c %04X:%04X\n", temp, AX, BX, CX, DX, (AL < 32) ? ' ' : AL, CS, pc);
|
|
|
|
|
// if (CS == 0x0028 && pc == 0xC03813C0)
|
|
|
|
|
// output = 3;
|
|
|
|
|
/* if (pc == 0x8028009A)
|
|
|
|
|
output = 3;
|
|
|
|
|
if (pc == 0x80282B6F)
|
|
|
|
|
{
|
|
|
|
|
__times++;
|
|
|
|
|
if (__times == 2)
|
|
|
|
|
fatal("WRONG\n");
|
|
|
|
|
}
|
|
|
|
|
if (pc == 0x802809CE)
|
|
|
|
|
fatal("RIGHT\n");*/
|
|
|
|
|
// if (CS == 0x0028 && pc == 0x80037FE9)
|
|
|
|
|
// output = 3;
|
|
|
|
|
//if (CS == 0x9087 && pc == 0x3763)
|
|
|
|
|
// fatal("Here\n");
|
|
|
|
|
//if (CS==0x9087 && pc == 0x0850)
|
|
|
|
|
// output = 1;
|
|
|
|
|
|
|
|
|
|
/* if (output && pc == 0x80033008)
|
|
|
|
|
{
|
|
|
|
|
__times++;
|
|
|
|
|
if (__times == 2)
|
|
|
|
|
fatal("WRONG\n");
|
|
|
|
|
}*/
|
|
|
|
|
/* if (output && pc == 0x80D8)
|
|
|
|
|
{
|
|
|
|
|
__times++;
|
|
|
|
|
if (__times == 2)
|
|
|
|
|
fatal("RIGHT\n");
|
|
|
|
|
}*/
|
|
|
|
|
|
|
|
|
|
x86_int_sw(temp);
|
2016-12-23 03:16:24 +01:00
|
|
|
PREFETCH_RUN(cycles_old-cycles, 2, -1, 0,0,0,0, 0);
|
2016-06-26 00:34:39 +02:00
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static int opINTO(uint32_t fetchdat)
|
|
|
|
|
{
|
2016-12-23 03:16:24 +01:00
|
|
|
int cycles_old = cycles;
|
|
|
|
|
|
2016-06-26 00:34:39 +02:00
|
|
|
if ((cr0 & 1) && (eflags & VM_FLAG) && (IOPL != 3))
|
|
|
|
|
{
|
|
|
|
|
x86gpf(NULL,0);
|
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
if (VF_SET())
|
|
|
|
|
{
|
2016-08-20 03:40:12 +02:00
|
|
|
cpu_state.oldpc = cpu_state.pc;
|
2016-06-26 00:34:39 +02:00
|
|
|
x86_int_sw(4);
|
2016-12-23 03:16:24 +01:00
|
|
|
PREFETCH_RUN(cycles_old-cycles, 1, -1, 0,0,0,0, 0);
|
2016-06-26 00:34:39 +02:00
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
CLOCK_CYCLES(3);
|
2016-12-23 03:16:24 +01:00
|
|
|
PREFETCH_RUN(3, 1, -1, 0,0,0,0, 0);
|
2016-06-26 00:34:39 +02:00
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|