Changes to device_t struct to accomodate the upcoming PCI IRQ arbitration rewrite; Added device.c/h API to obtain name from the device_t struct; Significant changes to win/win_settings.c to clean up the code a bit and fix bugs; Ported all the CPU and AudioPCI commits from PCem; Added an API call to allow ACPI soft power off to gracefully stop the emulator; Removed the Siemens PCD-2L from the Dev branch because it now works; Removed the Socket 5 HP Vectra from the Dev branch because it now works; Fixed the Compaq Presario and the Micronics Spitfire; Give the IBM PC330 its own list of 486 CPU so it can have DX2's with CPUID 0x470; SMM fixes; Rewrote the SYSENTER, SYSEXIT, SYSCALL, and SYSRET instructions; Changed IDE reset period to match the specification, fixes #929; The keyboard input and output ports are now forced in front of the queue when read, fixes a number of bugs, including the AMI Apollo hanging on soft reset; Added the Intel AN430TX but Dev branched because it does not work; The network code no longer drops packets if the emulated network card has failed to receive them (eg. when the buffer is full); Changes to PCI card adding and renamed some PCI slot types, also added proper AGP bridge slot types; USB UHCI emulation is no longer a stub (still doesn't fully work, but at least Windows XP chk with Debug no longer ASSERT's on it); Fixed NVR on the the SMC FDC37C932QF and APM variants; A number of fixes to Intel 4x0 chipsets, including fixing every register of the 440LX and 440EX; Some ACPI changes.
92 lines
2.7 KiB
C
92 lines
2.7 KiB
C
static int opINT3(uint32_t fetchdat)
|
|
{
|
|
int cycles_old = cycles; UN_USED(cycles_old);
|
|
if ((cr0 & 1) && (cpu_state.eflags & VM_FLAG) && (IOPL != 3))
|
|
{
|
|
x86gpf(NULL,0);
|
|
return 1;
|
|
}
|
|
x86_int_sw(3);
|
|
CLOCK_CYCLES((is486) ? 44 : 59);
|
|
PREFETCH_RUN(cycles_old-cycles, 1, -1, 0,0,0,0, 0);
|
|
return 1;
|
|
}
|
|
|
|
static int opINT1(uint32_t fetchdat)
|
|
{
|
|
int cycles_old = cycles; UN_USED(cycles_old);
|
|
if ((cr0 & 1) && (cpu_state.eflags & VM_FLAG) && (IOPL != 3))
|
|
{
|
|
x86gpf(NULL,0);
|
|
return 1;
|
|
}
|
|
x86_int_sw(1);
|
|
CLOCK_CYCLES((is486) ? 44 : 59);
|
|
PREFETCH_RUN(cycles_old-cycles, 1, -1, 0,0,0,0, 0);
|
|
return 1;
|
|
}
|
|
|
|
static int opINT(uint32_t fetchdat)
|
|
{
|
|
int cycles_old = cycles; UN_USED(cycles_old);
|
|
uint8_t temp = getbytef();
|
|
|
|
if ((cr0 & 1) && (cpu_state.eflags & VM_FLAG) && (IOPL != 3))
|
|
{
|
|
if (cr4 & CR4_VME)
|
|
{
|
|
uint16_t t;
|
|
uint8_t d;
|
|
|
|
cpl_override = 1;
|
|
t = readmemw(tr.base, 0x66) - 32;
|
|
cpl_override = 0;
|
|
if (cpu_state.abrt) return 1;
|
|
|
|
t += (temp >> 3);
|
|
if (t <= tr.limit)
|
|
{
|
|
cpl_override = 1;
|
|
d = readmemb(tr.base, t);// + (temp >> 3));
|
|
cpl_override = 0;
|
|
if (cpu_state.abrt) return 1;
|
|
|
|
if (!(d & (1 << (temp & 7))))
|
|
{
|
|
x86_int_sw_rm(temp);
|
|
PREFETCH_RUN(cycles_old-cycles, 2, -1, 0,0,0,0, 0);
|
|
return 1;
|
|
}
|
|
}
|
|
}
|
|
x86gpf_expected(NULL,0);
|
|
return 1;
|
|
}
|
|
|
|
x86_int_sw(temp);
|
|
PREFETCH_RUN(cycles_old-cycles, 2, -1, 0,0,0,0, 0);
|
|
return 1;
|
|
}
|
|
|
|
static int opINTO(uint32_t fetchdat)
|
|
{
|
|
int cycles_old = cycles; UN_USED(cycles_old);
|
|
|
|
if ((cr0 & 1) && (cpu_state.eflags & VM_FLAG) && (IOPL != 3))
|
|
{
|
|
x86gpf(NULL,0);
|
|
return 1;
|
|
}
|
|
if (VF_SET())
|
|
{
|
|
cpu_state.oldpc = cpu_state.pc;
|
|
x86_int_sw(4);
|
|
PREFETCH_RUN(cycles_old-cycles, 1, -1, 0,0,0,0, 0);
|
|
return 1;
|
|
}
|
|
CLOCK_CYCLES(3);
|
|
PREFETCH_RUN(3, 1, -1, 0,0,0,0, 0);
|
|
return 0;
|
|
}
|
|
|