From 3d5cebdab46e78dc99a1a36c3def5051b865e675 Mon Sep 17 00:00:00 2001 From: Guillaume DIDIER Date: Mon, 4 Nov 2019 14:48:49 +0100 Subject: [PATCH] Use entry_point! to typecheck the entry point and get the boot info. --- src/main.rs | 16 ++++++++++++++-- 1 file changed, 14 insertions(+), 2 deletions(-) diff --git a/src/main.rs b/src/main.rs index 20cc455..8809e4a 100644 --- a/src/main.rs +++ b/src/main.rs @@ -17,6 +17,8 @@ use vga_buffer; // required for custom panic handler use dendrobates_tinctoreus_azureus::hlt_loop; use x86_64; +use bootloader::BootInfo; + // Custom panic handler, required for freestanding program #[cfg(not(test))] #[panic_handler] @@ -28,9 +30,10 @@ fn panic(info: &PanicInfo) -> ! { hlt_loop(); } +entry_point!(kernel_main); + // Kernel entry point -#[no_mangle] -pub extern "C" fn _start() -> ! { +pub extern "C" fn kernal_main(boot_info: &'static BootInfo) -> ! { // TODO: Take care of cpuid stuff and set-up all floating point exetnsions // TODO: We may also need to enable debug registers ? @@ -44,6 +47,15 @@ pub extern "C" fn _start() -> ! { x86_64::instructions::interrupts::int3(); + use x86_64::registers::control::Cr3; + + let (level_4_page_table, flags) = Cr3::read(); + println!( + "Level 4 page table at: {:?}, flags {:?}", + level_4_page_table.start_address(), + flags + ); + unsafe { *(0xdeadbeef as *mut u64) = 42; }