1
0
mirror of https://github.com/cfenollosa/os-tutorial.git synced 2024-10-27 20:34:19 +00:00
cfenollosa_os-tutorial/23-fixes/cpu/idt.h

40 lines
1.0 KiB
C
Raw Normal View History

2015-08-17 16:41:38 +00:00
#ifndef IDT_H
#define IDT_H
2015-08-18 08:31:28 +00:00
#include <stdint.h>
2015-08-17 16:41:38 +00:00
/* Segment selectors */
#define KERNEL_CS 0x08
/* How every interrupt gate (handler) is defined */
typedef struct {
2015-08-18 08:31:28 +00:00
uint16_t low_offset; /* Lower 16 bits of handler function address */
uint16_t sel; /* Kernel segment selector */
uint8_t always0;
2015-08-17 16:41:38 +00:00
/* First byte
* Bit 7: "Interrupt is present"
* Bits 6-5: Privilege level of caller (0=kernel..3=user)
* Bit 4: Set to 0 for interrupt gates
* Bits 3-0: bits 1110 = decimal 14 = "32 bit interrupt gate" */
2015-08-18 08:31:28 +00:00
uint8_t flags;
uint16_t high_offset; /* Higher 16 bits of handler function address */
2015-08-17 16:41:38 +00:00
} __attribute__((packed)) idt_gate_t ;
/* A pointer to the array of interrupt handlers.
* Assembly instruction 'lidt' will read it */
typedef struct {
2015-08-18 08:31:28 +00:00
uint16_t limit;
uint32_t base;
2015-08-17 16:41:38 +00:00
} __attribute__((packed)) idt_register_t;
#define IDT_ENTRIES 256
idt_gate_t idt[IDT_ENTRIES];
idt_register_t idt_reg;
/* Functions implemented in idt.c */
2015-08-18 08:31:28 +00:00
void set_idt_gate(int n, uint32_t handler);
2015-08-17 16:41:38 +00:00
void set_idt();
#endif