blog_os/src/main.rs

89 lines
2.3 KiB
Rust
Raw Normal View History

2019-09-23 16:12:07 -04:00
#![no_std]
#![no_main]
2019-09-24 13:38:25 -04:00
#![feature(custom_test_frameworks)]
#![test_runner(blog_os::test_runner)]
#![reexport_test_harness_main = "test_main"]
2019-09-23 16:12:07 -04:00
2019-10-01 16:19:13 -04:00
extern crate alloc;
2020-01-21 16:49:07 -05:00
use alloc::{boxed::Box, rc::Rc, vec, vec::Vec};
2019-09-23 16:12:07 -04:00
use core::panic::PanicInfo;
2019-09-24 13:38:25 -04:00
use blog_os::println;
2020-05-13 10:27:56 -04:00
use blog_os::task::{keyboard, Task, executor::Executor};
2019-10-01 13:53:03 -04:00
use bootloader::{entry_point, BootInfo};
2019-09-24 10:20:27 -04:00
2019-09-23 16:12:07 -04:00
/// This function is called on panic.
2019-09-24 13:38:25 -04:00
#[cfg(not(test))]
2019-09-23 16:12:07 -04:00
#[panic_handler]
2019-09-24 10:20:27 -04:00
fn panic(info: &PanicInfo) -> ! {
println!("{}", info);
2019-09-25 15:32:02 -04:00
blog_os::hlt_loop();
2019-09-23 16:12:07 -04:00
}
2019-09-24 13:38:25 -04:00
#[cfg(test)]
#[panic_handler]
fn panic(info: &PanicInfo) -> ! {
blog_os::test_panic_handler(info)
}
2019-10-01 13:53:03 -04:00
entry_point!(kernel_main);
fn kernel_main(boot_info: &'static BootInfo) -> ! {
2019-10-01 16:19:13 -04:00
use blog_os::allocator;
use blog_os::memory::{self, BootInfoFrameAllocator};
use x86_64::VirtAddr;
2019-09-24 13:38:25 -04:00
2019-10-01 13:53:03 -04:00
println!("Hello World{}", "!");
2019-09-24 16:24:38 -04:00
blog_os::init();
2019-10-01 16:19:13 -04:00
let mut mapper = unsafe { memory::init(VirtAddr::new(boot_info.physical_memory_offset)) };
2020-01-21 16:49:07 -05:00
let mut frame_allocator = unsafe { BootInfoFrameAllocator::init(&boot_info.memory_map) };
2019-10-01 16:19:13 -04:00
2020-01-21 16:49:07 -05:00
allocator::init_heap(&mut mapper, &mut frame_allocator).expect("heap initialization failed");
2019-10-01 13:53:03 -04:00
2019-10-01 16:19:13 -04:00
// allocate a number on the heap
let heap_value = Box::new(41);
println!("heap_value at {:p}", heap_value);
2019-10-01 13:53:03 -04:00
2019-10-01 16:19:13 -04:00
// create a dynamically sized vector
let mut vec = Vec::new();
for i in 0..500 {
vec.push(i);
2019-10-01 13:53:03 -04:00
}
2019-10-01 16:19:13 -04:00
println!("vec at {:p}", vec.as_slice());
// create a reference counted vector -> will be freed when count reaches 0
let reference_counted = Rc::new(vec![1, 2, 3]);
let cloned_reference = reference_counted.clone();
2020-01-21 16:49:07 -05:00
println!(
"current reference count is {}",
Rc::strong_count(&cloned_reference)
);
2019-10-01 16:19:13 -04:00
core::mem::drop(reference_counted);
2020-01-21 16:49:07 -05:00
println!(
"reference count is {} now",
Rc::strong_count(&cloned_reference)
);
2019-10-01 13:53:03 -04:00
2020-05-13 10:27:56 -04:00
let mut executor = Executor::new();
2020-05-12 16:51:22 -04:00
executor.spawn(Task::new(example_task()));
executor.spawn(Task::new(keyboard::print_keypresses()));
executor.run();
2019-09-24 13:38:25 -04:00
#[cfg(test)]
test_main();
2019-09-23 16:31:22 -04:00
2019-09-24 16:59:20 -04:00
println!("It did not crash!");
2019-09-25 15:32:02 -04:00
blog_os::hlt_loop();
2019-09-23 16:12:07 -04:00
}
2020-05-12 16:51:22 -04:00
async fn async_number() -> u32 {
42
}
async fn example_task() {
let number = async_number().await;
println!("async number: {}", number);
}