setup idt
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
diff --git a/include/bios.h b/include/bios.h
index 22a912a..fcfc5ba 100644
--- a/include/bios.h
+++ b/include/bios.h
@@ -31,6 +31,10 @@
extern bioscall void int15_handler(struct biosregs *regs);
extern bioscall void e820_query_map(struct biosregs *regs);
+extern void bios_intfake(void);
+extern void bios_int10(void);
+extern void bios_int15(void);
+
extern struct e820map e820;
static inline void __attribute__((noreturn)) panic(void)
diff --git a/main.c b/main.c
index eeb21fd..ed871df 100644
--- a/main.c
+++ b/main.c
@@ -1,6 +1,7 @@
#include "bios.h"
#include "pci.h"
#include "string.h"
+#include "segment.h"
#define PCI_VENDOR_ID_INTEL 0x8086
#define PCI_DEVICE_ID_INTEL_82441 0x1237
@@ -37,13 +38,31 @@
memcpy(low_start, bios_start, 0x10000);
}
+static void set_realmode_int(int vec, void *p)
+{
+ uint16_t *realmode_idt = (uint16_t *) 0;
+ realmode_idt[vec * 2] = flat_to_off16((uintptr_t) p);
+ realmode_idt[vec * 2 + 1] = flat_to_seg16((uintptr_t) p);
+}
+
+static void setup_idt(void)
+{
+ int i;
+ for (i = 0; i < 0x1f; i++)
+ set_realmode_int(i, bios_intfake);
+ set_realmode_int(0x10, bios_int10);
+ set_realmode_int(0x15, bios_int15);
+}
int main(void)
{
make_bios_writable();
+ setup_idt();
// extract_acpi();
+ // extract_e820();
// extract_smbios();
// extract_kernel();
+ // make_bios_readonly();
// boot_linux();
panic();
}