dendrobates-t-azureus/src/main.rs

136 lines
3.2 KiB
Rust
Raw Normal View History

// main.rs
// main file of the kernel
#![no_std] // This is a free standing program
#![no_main] // This has no crt0
#![feature(custom_test_frameworks)]
#![test_runner(dendrobates_tinctoreus_azureus::test_runner)]
#![reexport_test_harness_main = "test_main"]
2019-11-13 14:12:07 +01:00
use polling_serial::serial_println;
2019-11-13 14:26:39 +01:00
#[cfg(test)]
use polling_serial::serial_print;
use vga_buffer::println;
use core::panic::PanicInfo;
use vga_buffer; // required for custom panic handler
use x86_64;
use bootloader::{entry_point, BootInfo};
2019-11-13 14:26:39 +01:00
#[cfg(not(test))]
use dendrobates_tinctoreus_azureus::hlt_loop;
#[cfg(not(test))]
use vga_buffer::{set_colors, Color, ForegroundColor};
// Custom panic handler, required for freestanding program
#[cfg(not(test))]
#[panic_handler]
fn panic(info: &PanicInfo) -> ! {
serial_println!("{}", info);
set_colors(ForegroundColor::LightRed, Color::Blue);
println!("{}", info);
x86_64::instructions::bochs_breakpoint();
hlt_loop();
}
entry_point!(kernel_main);
// Kernel entry point
2019-11-13 14:26:39 +01:00
fn kernel_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 ?
println!("Hello Blue Frog");
dendrobates_tinctoreus_azureus::init();
x86_64::instructions::interrupts::int3(); // new
#[cfg(test)]
test_main();
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
);
serial_println!(
"Level 4 page table at: {:?}, flags {:?}",
level_4_page_table.start_address(),
flags
);
serial_println!("Preparing nasty fault...");
unsafe {
2019-11-13 14:12:07 +01:00
*(0xdead_beef as *mut u64) = 42;
}
serial_println!("Survived ? oO");
// magic break ?
// x86_64::instructions::bochs_breakpoint();
panic!("Ooops Sorry");
}
#[cfg(test)]
#[panic_handler]
fn panic(info: &PanicInfo) -> ! {
use dendrobates_tinctoreus_azureus::test_panic_handler;
test_panic_handler(info);
}
#[test_case]
fn float_test() {
serial_println!("Testing float computations...");
use volatile::Volatile;
// Make a few floating points test;
let vf: f32 = 84798.0;
let vd: f64 = 0.828494623655914;
let a: Volatile<f32> = Volatile::new(42.0);
let b: Volatile<f32> = Volatile::new(2019.);
let rf = a.read() * b.read();
let c: Volatile<f64> = Volatile::new(15.410);
let d: Volatile<f64> = Volatile::new(18.600);
let rd = c.read() / d.read();
serial_print!(
" {:?} * {:?} = {:?} expected {:?}...",
a.read(),
b.read(),
rf,
vf
);
2019-11-13 14:26:39 +01:00
if rf == vf {
serial_println!("[ok]");
} else {
serial_println!("[fail]");
}
serial_print!(
" {:?} / {:?} = {:?} expected {:?}...",
c.read(),
d.read(),
rd,
vd
);
2019-11-13 14:26:39 +01:00
if rd == vd {
serial_println!("[ok]");
} else {
serial_println!("[fail]");
}
assert_eq!(rf, vf);
assert_eq!(rd, vd);
serial_println!("Testing float computations... [ok]");
}