summaryrefslogtreecommitdiff
path: root/arch/i386/include/kernel/pic.h
blob: 187d553595ce2f5f26009ed81f6fd911f5177fc6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
#ifndef I386_PIC_H
#define I386_PIC_H

#include <kernel/asm.h>
#include <stdint.h>

#define PIC1            0x20
#define PIC2            0x28
#define PIC1_COMMAND    PIC1
#define PIC1_DATA       (PIC1+1)
#define PIC2_COMMAND    PIC2
#define PIC2_DATA       (PIC2+1)

#define ICW1_ICW4       0x01
#define ICW1_SINGLE     0x02
#define ICW1_INTERVAL4  0x04
#define ICW1_LEVEL      0x08
#define ICW1_INIT       0x10

#define ICW4_8086       0x01
#define ICW4_AUTO       0x02
#define ICW4_BUF_SLAVE  0x08
#define ICW4_BUF_MASTER 0x0C
#define ICW4_SFNM       0x10

#define PIC_READ_IRR    0x0A
#define PIC_READ_ISR    0x0B

static inline void io_wait(void) {
        outb(0x80, 0);
}

void pic_eoi(uint8_t irq);
void pic_remap(void);
uint16_t pic_get_irr(void);
uint16_t pic_get_isr(void);

void register_irq_handler(uint8_t irq, void (*handler)(struct isr_frame *frame));
void irq_dispatch(struct isr_frame *frame);

void irq_set_mask(uint8_t irq);
void irq_clear_mask(uint8_t irq);

#endif