2020-11-10 23:02:38 +08:00
|
|
|
#![no_std]
|
|
|
|
#![no_main]
|
2020-11-13 12:06:39 +08:00
|
|
|
#![feature(panic_info_message)]
|
2020-12-02 10:32:26 +08:00
|
|
|
#![feature(alloc_error_handler)]
|
2022-12-13 23:52:27 +08:00
|
|
|
|
2023-01-07 23:35:11 +08:00
|
|
|
//use crate::drivers::{GPU_DEVICE, KEYBOARD_DEVICE, MOUSE_DEVICE, INPUT_CONDVAR};
|
2022-06-18 15:23:16 +08:00
|
|
|
use crate::drivers::{GPU_DEVICE, KEYBOARD_DEVICE, MOUSE_DEVICE};
|
2020-12-02 10:32:26 +08:00
|
|
|
extern crate alloc;
|
2020-11-10 23:02:38 +08:00
|
|
|
|
2020-12-04 17:23:35 +08:00
|
|
|
#[macro_use]
|
|
|
|
extern crate bitflags;
|
|
|
|
|
2022-01-24 23:23:03 -08:00
|
|
|
#[path = "boards/qemu.rs"]
|
|
|
|
mod board;
|
|
|
|
|
2020-11-12 17:13:57 +08:00
|
|
|
#[macro_use]
|
|
|
|
mod console;
|
2022-01-22 12:40:54 -08:00
|
|
|
mod config;
|
|
|
|
mod drivers;
|
|
|
|
mod fs;
|
2020-11-13 12:06:39 +08:00
|
|
|
mod lang_items;
|
2022-01-22 12:40:54 -08:00
|
|
|
mod mm;
|
2020-11-13 12:06:39 +08:00
|
|
|
mod sbi;
|
2022-01-22 12:40:54 -08:00
|
|
|
mod sync;
|
2020-11-18 18:29:53 +08:00
|
|
|
mod syscall;
|
2020-11-29 01:31:36 +08:00
|
|
|
mod task;
|
2020-11-29 10:31:15 +08:00
|
|
|
mod timer;
|
2022-01-22 12:40:54 -08:00
|
|
|
mod trap;
|
2023-02-06 19:21:43 +08:00
|
|
|
mod net;
|
2020-11-10 23:02:38 +08:00
|
|
|
|
2023-01-03 09:32:36 +08:00
|
|
|
use crate::drivers::chardev::CharDevice;
|
|
|
|
use crate::drivers::chardev::UART;
|
2022-06-20 22:41:20 +08:00
|
|
|
|
2022-02-07 14:13:30 -08:00
|
|
|
core::arch::global_asm!(include_str!("entry.asm"));
|
2020-11-11 16:50:00 +08:00
|
|
|
|
2020-11-13 12:06:39 +08:00
|
|
|
fn clear_bss() {
|
|
|
|
extern "C" {
|
|
|
|
fn sbss();
|
|
|
|
fn ebss();
|
|
|
|
}
|
2021-07-21 19:10:04 +08:00
|
|
|
unsafe {
|
2022-01-22 12:40:54 -08:00
|
|
|
core::slice::from_raw_parts_mut(sbss as usize as *mut u8, ebss as usize - sbss as usize)
|
|
|
|
.fill(0);
|
2021-07-21 19:10:04 +08:00
|
|
|
}
|
2020-11-13 12:06:39 +08:00
|
|
|
}
|
|
|
|
|
2022-02-07 14:13:30 -08:00
|
|
|
use lazy_static::*;
|
2022-03-04 09:02:32 -08:00
|
|
|
use sync::UPIntrFreeCell;
|
2022-02-07 14:13:30 -08:00
|
|
|
|
|
|
|
lazy_static! {
|
2022-05-14 22:53:45 +08:00
|
|
|
pub static ref DEV_NON_BLOCKING_ACCESS: UPIntrFreeCell<bool> =
|
|
|
|
unsafe { UPIntrFreeCell::new(false) };
|
2022-02-07 14:13:30 -08:00
|
|
|
}
|
|
|
|
|
2020-11-11 16:50:00 +08:00
|
|
|
#[no_mangle]
|
2020-11-11 23:40:00 +08:00
|
|
|
pub fn rust_main() -> ! {
|
2020-11-13 12:06:39 +08:00
|
|
|
clear_bss();
|
2020-12-03 10:40:30 +08:00
|
|
|
mm::init();
|
2023-01-03 09:32:36 +08:00
|
|
|
UART.init();
|
2022-06-18 17:50:50 +08:00
|
|
|
println!("KERN: init gpu");
|
2022-12-19 03:55:58 -08:00
|
|
|
let _gpu = GPU_DEVICE.clone();
|
2022-06-18 17:50:50 +08:00
|
|
|
println!("KERN: init keyboard");
|
2022-12-19 03:55:58 -08:00
|
|
|
let _keyboard = KEYBOARD_DEVICE.clone();
|
2022-06-18 17:50:50 +08:00
|
|
|
println!("KERN: init mouse");
|
2022-12-19 03:55:58 -08:00
|
|
|
let _mouse = MOUSE_DEVICE.clone();
|
2022-06-18 17:50:50 +08:00
|
|
|
println!("KERN: init trap");
|
2020-11-20 01:18:25 +08:00
|
|
|
trap::init();
|
2020-12-07 18:57:23 +08:00
|
|
|
trap::enable_timer_interrupt();
|
|
|
|
timer::set_next_trigger();
|
2022-02-07 14:13:30 -08:00
|
|
|
board::device_init();
|
2020-12-20 00:52:14 +08:00
|
|
|
fs::list_apps();
|
|
|
|
task::add_initproc();
|
2022-02-07 14:13:30 -08:00
|
|
|
*DEV_NON_BLOCKING_ACCESS.exclusive_access() = true;
|
2020-12-08 15:37:10 +08:00
|
|
|
task::run_tasks();
|
2020-11-29 01:31:36 +08:00
|
|
|
panic!("Unreachable in rust_main!");
|
2021-09-30 10:09:21 -07:00
|
|
|
}
|