Provide command-and-control interface for testing kernel parts
This commit is contained in:
parent
7ea82d90d7
commit
e7526e7fc3
86
src/main.rs
86
src/main.rs
|
@ -126,14 +126,7 @@ fn init_uart_serial() {
|
|||
println!("[0] UART0 is live!");
|
||||
}
|
||||
|
||||
// Kernel entry point
|
||||
// arch crate is responsible for calling this
|
||||
fn kmain() -> ! {
|
||||
init_jlink_rtt();
|
||||
|
||||
// init_uart_serial();
|
||||
// jtag_dbg_wait();
|
||||
|
||||
fn init_exception_traps() {
|
||||
extern "C" {
|
||||
static __exception_vectors_start: u64;
|
||||
}
|
||||
|
@ -142,16 +135,61 @@ fn kmain() -> ! {
|
|||
let exception_vectors_start: u64 = &__exception_vectors_start as *const _ as u64;
|
||||
|
||||
arch::traps::set_vbar_el1_checked(exception_vectors_start);
|
||||
println!("Exception traps set up");
|
||||
}
|
||||
println!("Exception traps set up");
|
||||
}
|
||||
|
||||
// Kernel entry point
|
||||
// arch crate is responsible for calling this
|
||||
fn kmain() -> ! {
|
||||
init_jlink_rtt();
|
||||
init_uart_serial();
|
||||
init_exception_traps();
|
||||
|
||||
//------------------------------------------------------------
|
||||
// Start a command prompt
|
||||
//------------------------------------------------------------
|
||||
'cmd_loop: loop {
|
||||
let mut buf = [0u8; 64];
|
||||
|
||||
match CONSOLE.lock(|c| c.command_prompt(&mut buf)) {
|
||||
b"mmu" => init_mmu(),
|
||||
b"uart" => init_uart_serial(),
|
||||
b"disp" => check_display_init(),
|
||||
b"trap" => check_data_abort_trap(),
|
||||
b"map" => arch::memory::print_layout(),
|
||||
b"help" => print_help(),
|
||||
b"end" => break 'cmd_loop,
|
||||
x => println!("Unknown command {:?}, try 'help'", x),
|
||||
}
|
||||
}
|
||||
|
||||
println!("Bye, going to reset now");
|
||||
reboot()
|
||||
}
|
||||
|
||||
fn print_help() {
|
||||
println!("Supported console commands:");
|
||||
println!(" mmu - initialize MMU");
|
||||
println!(" uart - try to reinitialize UART serial");
|
||||
println!(" disp - try to init VC framebuffer and draw some text");
|
||||
println!(" trap - cause and recover from a data abort exception");
|
||||
println!(" map - show kernel memory layout");
|
||||
println!(" end - leave console and lock up");
|
||||
}
|
||||
|
||||
fn init_mmu() {
|
||||
unsafe {
|
||||
mmu::init();
|
||||
}
|
||||
println!("MMU initialised");
|
||||
}
|
||||
|
||||
// jtag_dbg_wait();
|
||||
fn reboot() -> ! {
|
||||
Power::new().reset()
|
||||
}
|
||||
|
||||
fn check_display_init() {
|
||||
if let Some(mut display) = VC::init_fb(Size2d { x: 800, y: 600 }, 32) {
|
||||
println!("Display created");
|
||||
|
||||
|
@ -176,34 +214,6 @@ fn kmain() -> ! {
|
|||
display.draw_text(160, 60, "GREEN", Color::green());
|
||||
display.draw_text(170, 70, "BLUE", Color::blue());
|
||||
}
|
||||
|
||||
// jtag_dbg_wait();
|
||||
|
||||
//------------------------------------------------------------
|
||||
// Start a command prompt
|
||||
//------------------------------------------------------------
|
||||
'cmd_loop: loop {
|
||||
let mut buf = [0u8; 64];
|
||||
|
||||
match CONSOLE.lock(|c| c.command_prompt(&mut buf)) {
|
||||
b"trap" => check_data_abort_trap(),
|
||||
b"map" => arch::memory::print_layout(),
|
||||
b"help" => print_help(),
|
||||
b"end" => break 'cmd_loop,
|
||||
x => println!("Unknown command {:?}, try 'help'", x),
|
||||
}
|
||||
}
|
||||
|
||||
println!("Bye, going to sleep now");
|
||||
// qemu_aarch64_exit()
|
||||
endless_sleep()
|
||||
}
|
||||
|
||||
fn print_help() {
|
||||
println!("Supported console commands:");
|
||||
println!(" trap - cause and recover from a data abort exception");
|
||||
println!(" map - show kernel memory layout");
|
||||
println!(" end - leave console and lock up");
|
||||
}
|
||||
|
||||
fn check_data_abort_trap() {
|
||||
|
|
Loading…
Reference in New Issue