Asuro/src/idt.pas
2018-10-12 20:49:03 +00:00

75 lines
1.7 KiB
ObjectPascal

{
Interrupt Descriptor Table - Structures & Interface.
@author(Kieron Morris <kjm@kieronmorris.me>)
}
unit idt;
interface
uses
util, console;
const
ISR_RING_0 = $8E;
ISR_RING_1 = $AE;
ISR_RING_2 = $CE;
ISR_RING_3 = $EE;
type
TIDT_Entry = packed record
base_low : uint16;
selector : uint16;
always_0 : uint8;
flags : uint8;
base_high : uint16;
end;
PIDT_Entry = ^TIDT_Entry;
TIDT_Pointer = packed record
limit : uint16;
base : uint32;
end;
PIDT_Pointer = ^TIDT_Pointer;
var
IDT_Entries : Array [0..255] of TIDT_Entry;
IDT_Pointer : TIDT_Pointer;
procedure init();
procedure set_gate(Number : uint8; Base : uint32; Selector : uint16; Flags : uint8);
implementation
procedure load(idt_pointer : uint32); assembler; nostackframe;
asm
MOV EAX, idt_pointer
LIDT [EAX]
end;
procedure set_gate(Number : uint8; Base : uint32; Selector : uint16; Flags : uint8);
begin
IDT_Entries[Number].base_high:= (Base and $FFFF0000) SHR 16;
IDT_Entries[Number].base_low:= (Base and $0000FFFF);
IDT_Entries[Number].selector:= Selector;
IDT_Entries[Number].flags:= Flags;
IDT_Entries[Number].always_0:= $00;
console.output('IDT','GATE ');
console.writeint(Number);
console.writestringln(' SET.');
load(uint32(@IDT_Pointer));
end;
procedure init();
begin
console.outputln('IDT','INIT START.');
IDT_Pointer.limit:= (sizeof(TIDT_Entry) * 256) - 1;
IDT_Pointer.base:= uint32(@IDT_Entries);
console.outputln('IDT','CLEAR.');
util.memset(uint32(@IDT_Entries[0]), 0, sizeof(TIDT_Entry) * 256);
console.outputln('IDT','LOAD.');
load(uint32(@IDT_Pointer));
console.outputln('IDT','INIT END.');
end;
end.