static void pic_intr_handler(struct Interrupt_State * state) {
Begin_IRQ(state);
struct guest_info * info = irq_map[state->intNum - 32];
- SerialPrint("Interrupt %d\n", state->intNum);
+ SerialPrint("Interrupt %d (IRQ=%d)\n", state->intNum, state->intNum - 32);
if (info) {
- SerialPrint("Calling handler(info=%x)->%x\n", info, info->vm_ops.raise_irq);
info->vm_ops.raise_irq(info, state->intNum - 32, state->errorCode);
} else {
SerialPrint("Interrupt handler error: NULL pointer found, no action taken\n");
SerialPrint("Hooking IRQ: %d (vm=0x%x)\n", irq, info);
irq_map[irq] = info;
- Install_IRQ(irq, pic_intr_handler);
- Enable_IRQ(irq);
+ volatile void *foo = pic_intr_handler;
+ foo=0;
+ // Install_IRQ(irq, pic_intr_handler);
+ // Enable_IRQ(irq);
return 0;
}