gems-kernel/source/THIRDPARTY/nanobyte_os/kernel/arch/i686/irq.c
2024-06-03 11:16:15 -05:00

46 lines
1 KiB
C

#include "irq.h"
#include "pic.h"
#include "io.h"
#include <stddef.h>
#define PIC_REMAP_OFFSET 0x20
IRQHandler g_IRQHandlers[16];
void i686_IRQ_Handler(Registers* regs)
{
int irq = regs->interrupt - PIC_REMAP_OFFSET;
uint8_t pic_isr = i686_PIC_ReadInServiceRegister();
uint8_t pic_irr = i686_PIC_ReadIrqRequestRegister();
if (g_IRQHandlers[irq] != NULL)
{
// handle IRQ
g_IRQHandlers[irq](regs);
}
else
{
printf("Unhandled IRQ %d ISR=%x IRR=%x...\n", irq, pic_isr, pic_irr);
}
// send EOI
i686_PIC_SendEndOfInterrupt(irq);
}
void i686_IRQ_Initialize()
{
i686_PIC_Configure(PIC_REMAP_OFFSET, PIC_REMAP_OFFSET + 8);
// register ISR handlers for each of the 16 irq lines
for (int i = 0; i < 16; i++)
i686_ISR_RegisterHandler(PIC_REMAP_OFFSET + i, i686_IRQ_Handler);
// enable interrupts
i686_EnableInterrupts();
}
void i686_IRQ_RegisterHandler(int irq, IRQHandler handler)
{
g_IRQHandlers[irq] = handler;
}