blob: 7cafb4fbe32550cc9a497c3531685b9ee4ff53b5 (
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
45
46
47
48
49
|
//! IDT - Interrupt Descriptor Table
const gdt = @import("../boot/gdt/gdt.zig");
const asm_int = @import("../asm/interrupts/interrupts.zig");
pub const types = @import("types/types.zig");
pub const table = @import("table/table.zig");
pub const handlers = @import("handlers/handlers.zig");
pub const load = @import("load/load.zig");
pub const pic = @import("pic/pic.zig");
pub const Gate64 = types.Gate64;
pub const Descriptor = types.Descriptor;
pub const InterruptFrame = handlers.InterruptFrame;
pub const set_gate = table.set_gate;
pub const set_interrupt = table.set_interrupt;
pub const set_trap = table.set_trap;
pub const register_irq = handlers.register_irq;
pub const unregister_irq = handlers.unregister_irq;
pub fn initialize() void {
pic.remap();
pic.mask_all();
const selector = gdt.selectors.kernel_code_selector;
for (0..32) |i| {
const vector: u8 = @truncate(i);
const handler_ptr = @intFromPtr(handlers.exceptions.stubs[i]);
table.set_interrupt(vector, handler_ptr, selector);
}
for (0..16) |i| {
const vector: u8 = @truncate(i + 32);
const handler_ptr = @intFromPtr(handlers.hardware.stubs[i]);
table.set_interrupt(vector, handler_ptr, selector);
}
load.load();
}
pub fn enable() void {
asm_int.enable();
}
pub fn disable() void {
asm_int.disable();
}
|