ableos/kernel/src/kmain.rs

83 lines
1.9 KiB
Rust
Raw Normal View History

2023-03-30 16:43:04 -05:00
//! AbleOS Kernel Entrypoint
2023-04-07 16:44:33 -05:00
// use std::collections::HashMap;
2023-05-06 06:50:24 -05:00
use {
log::info,
2023-05-06 06:50:24 -05:00
spin::{Lazy, Mutex},
};
2023-04-05 12:29:20 -05:00
2023-05-23 05:16:14 -05:00
use hbvm::engine::Engine;
2023-05-15 02:19:34 -05:00
use crate::{
2023-05-23 05:16:14 -05:00
arch::logging::SERIAL_CONSOLE,
2023-05-15 02:19:34 -05:00
device_tree::DeviceTree,
// host_functions::read_device_tree,
};
2023-04-05 12:29:20 -05:00
use crate::alloc::string::ToString;
2023-03-30 16:43:04 -05:00
pub fn kmain(cmdline: &str, bootstrap: Option<&'static [u8]>) -> ! {
log::debug!("Entered kmain");
2023-04-05 12:29:20 -05:00
let mut cmdline = cmdline.to_string();
cmdline.pop();
cmdline.remove(0);
let kcmd = clparse::Arguments::parse(cmdline.to_string()).unwrap();
log::info!("Cmdline: {kcmd:?}");
2023-05-06 06:50:24 -05:00
if kcmd.arguments.get("baka") == Some(&"true".to_string()) {
let _ = crate::arch::log(format_args!(include_str!("../data/⑨. バカ")));
}
2023-03-30 16:43:04 -05:00
2023-05-06 06:50:24 -05:00
if kcmd.arguments.get("foobles") == Some(&"true".to_string()) {
let _ = crate::arch::log(format_args!("foobles\n\r"));
}
2023-04-07 16:44:33 -05:00
2023-04-05 12:29:20 -05:00
let bootstrap = bootstrap/*.expect("no bootstrap found")*/;
match bootstrap {
2023-05-23 05:16:14 -05:00
Some(_bootstrap_mod) => {}
2023-04-05 12:29:20 -05:00
None => {
info!("No bootstrap module loaded.")
}
}
2023-05-23 05:16:14 -05:00
let dt = DEVICE_TREE.lock();
2023-04-05 12:29:20 -05:00
2023-05-06 06:50:24 -05:00
info!("Device Tree {}", &dt);
2023-05-15 02:19:34 -05:00
let bytes = alloc::vec![0];
let mut prog = Engine::new(bytes);
// prog.enviroment_call_table[0] = read_device_tree;
2023-05-23 05:16:14 -05:00
let _ = prog.run();
2023-05-15 02:19:34 -05:00
prog.dump();
// TODO: change this to a driver
{
2023-05-23 05:16:14 -05:00
let _buf = [8; 128 * 4];
2023-05-15 02:19:34 -05:00
let mut sc = SERIAL_CONSOLE.lock();
loop {
let byte = sc.receive();
if byte == b'\r' {
sc.send(b'\n');
}
sc.send(byte);
}
}
2023-05-23 05:16:14 -05:00
// crate::arch::sloop()
2023-03-30 16:43:04 -05:00
}
2023-04-10 01:16:30 -05:00
2023-05-06 06:50:24 -05:00
pub static DEVICE_TREE: Lazy<Mutex<DeviceTree>> = Lazy::new(|| {
2023-05-23 05:16:14 -05:00
let dt = DeviceTree::new();
2023-05-06 06:50:24 -05:00
Mutex::new(dt)
});
2023-05-15 02:19:34 -05:00
#[test_case]
fn trivial_assertion() {
trace!("trivial assertion... ");
assert_eq!(1, 1);
info!("[ok]");
}