2021-07-21 18:30:55 +00:00
|
|
|
#include "idt.h"
|
|
|
|
#include "io.h"
|
|
|
|
#include "pic.h"
|
2021-07-25 22:24:04 +00:00
|
|
|
#include "stdio.h"
|
2021-07-21 18:30:55 +00:00
|
|
|
|
|
|
|
static void send_icw1(void)
|
|
|
|
{
|
|
|
|
outb(MASTER_PIC_A, ICW1);
|
|
|
|
outb(SLAVE_PIC_A, ICW1);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void send_icw2(void)
|
|
|
|
{
|
|
|
|
outb(MASTER_PIC_B, IDT_RESERVED_ENTRIES);
|
|
|
|
outb(SLAVE_PIC_B, IDT_RESERVED_ENTRIES + 8);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void send_icw3(void)
|
|
|
|
{
|
|
|
|
outb(MASTER_PIC_B, 0x4);
|
|
|
|
outb(SLAVE_PIC_B, 0x2);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static void send_icw4(void)
|
|
|
|
{
|
|
|
|
outb(MASTER_PIC_B, 0x1);
|
|
|
|
outb(SLAVE_PIC_B, 0x1);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void mask_irqs(void)
|
|
|
|
{
|
2021-07-21 18:38:20 +00:00
|
|
|
outb(MASTER_PIC_B, 0xff ^ 0x2);
|
2021-07-21 18:30:55 +00:00
|
|
|
outb(SLAVE_PIC_B, 0xff);
|
|
|
|
}
|
|
|
|
|
|
|
|
void init_pic(void)
|
|
|
|
{
|
|
|
|
send_icw1();
|
|
|
|
send_icw2();
|
|
|
|
send_icw3();
|
|
|
|
send_icw4();
|
|
|
|
mask_irqs();
|
|
|
|
asm volatile("sti");
|
|
|
|
}
|
2021-07-25 22:24:04 +00:00
|
|
|
|
|
|
|
void acknowledge(uint32_t int_vector)
|
|
|
|
{
|
|
|
|
printf("acknowledging %d\r\n", int_vector);
|
|
|
|
uint8_t ocw2 = 0x20;
|
|
|
|
if (int_vector >= IDT_RESERVED_ENTRIES + 8)
|
|
|
|
outb(SLAVE_PIC_A, ocw2);
|
|
|
|
outb(MASTER_PIC_A, ocw2);
|
|
|
|
}
|