summaryrefslogtreecommitdiff
path: root/kernel/src/main.rs
diff options
context:
space:
mode:
authorDennis Kobert <dennis@kobert.dev>2021-04-18 19:01:54 +0200
committerDennis Kobert <dennis@kobert.dev>2021-04-18 19:01:54 +0200
commit496ccaaf750a4ec1c537c463eff56108e1cc0bb4 (patch)
treef0ccffc3fd823cc4016c29d45408c033c973e5d5 /kernel/src/main.rs
parent8b810a009f8d29ba61a3c377fdeac06a3bbb151d (diff)
Further cleanupfurther-cleanup
* Bump x86_64 dep to version 0.1.14 * Rewrite LOCAL_APIC handling * Remove warnings
Diffstat (limited to 'kernel/src/main.rs')
-rw-r--r--kernel/src/main.rs12
1 files changed, 9 insertions, 3 deletions
diff --git a/kernel/src/main.rs b/kernel/src/main.rs
index 50b281f..017f4b9 100644
--- a/kernel/src/main.rs
+++ b/kernel/src/main.rs
@@ -19,8 +19,12 @@ extern "C" fn _start() -> ! {
interrupts::gdt::init();
interrupts::idt::init();
- let apic = interrupts::apic::Apic::new().expect("no APIC support");
- let apic = unsafe { interrupts::apic::set_local_apic(apic) };
+ loop {}
+ let apic = unsafe {
+ interrupts::apic::try_initialize_local_apic()
+ .as_mut()
+ .expect("no APIC support")
+ };
apic.set_timer_interrupt_handler(
interrupts::apic::TimerDivideConfig::Div16,
@@ -31,11 +35,13 @@ extern "C" fn _start() -> ! {
let mut stdout = OStream::new();
stdout.print(b"apic initialisation complete\n");
- x86_64::instructions::interrupts::int3();
+ //x86_64::instructions::interrupts::int3();
+ stdout.print(b"foolete\n");
if cfg!(test) {
qemu::exit_qemu(qemu::QemuExitCode::Success);
}
+ #[allow(clippy::empty_loop)]
loop {}
}