1
0
Fork 0
forked from koniifer/ableos

Console logging

This commit is contained in:
Erin 2023-01-08 00:44:13 +01:00 committed by ondra05
parent b5f75a13f4
commit 816204cd5b
4 changed files with 55 additions and 17 deletions

View file

@ -0,0 +1,46 @@
//! Logging (as in terms of console / serial output)
use core::fmt::Write;
use limine::{LimineTerminalRequest, LimineTerminalResponse};
use spin::{Lazy, Mutex};
use uart_16550::SerialPort;
static SERIAL_CONSOLE: Mutex<SerialPort> = Mutex::new(unsafe { SerialPort::new(0x3f8) });
static TERMINAL_LOGGER: Lazy<Mutex<TermLogger>> = Lazy::new(|| Mutex::new(TermLogger::new()));
pub fn init() {
SERIAL_CONSOLE.lock().init();
Lazy::force(&TERMINAL_LOGGER);
}
pub fn log(args: core::fmt::Arguments<'_>) -> core::fmt::Result {
x86_64::instructions::interrupts::without_interrupts(|| {
TERMINAL_LOGGER.lock().write_fmt(args)?;
SERIAL_CONSOLE.lock().write_fmt(args)
})
}
struct TermLogger(&'static LimineTerminalResponse);
unsafe impl Send for TermLogger {}
impl TermLogger {
pub fn new() -> Self {
static TERM_REQ: LimineTerminalRequest = LimineTerminalRequest::new(0);
Self(
TERM_REQ
.get_response()
.get()
.expect("failed to get terminal response"),
)
}
}
impl Write for TermLogger {
fn write_str(&mut self, s: &str) -> core::fmt::Result {
if let (Some(w), Some(ts)) = (self.0.write(), self.0.terminals()) {
for term in ts {
w(term, s);
}
}
Ok(())
}
}

View file

@ -1,19 +1,17 @@
use limine::{LimineHhdmRequest, LimineKernelFileRequest, LimineMmapRequest, LimineModuleRequest}; pub use logging::log;
use spin::Mutex;
use uart_16550::SerialPort;
use x86_64::VirtAddr;
use crate::allocator; use crate::allocator;
use limine::{LimineHhdmRequest, LimineKernelFileRequest, LimineMmapRequest, LimineModuleRequest};
use x86_64::VirtAddr;
mod gdt; mod gdt;
mod interrupts; mod interrupts;
mod logging;
mod memory; mod memory;
static SERIAL_CONSOLE: Mutex<SerialPort> = Mutex::new(unsafe { SerialPort::new(0x3f8) });
#[no_mangle] #[no_mangle]
unsafe extern "C" fn _kernel_start() -> ! { unsafe extern "C" fn _kernel_start() -> ! {
SERIAL_CONSOLE.lock().init(); logging::init();
crate::logger::init().expect("failed to set logger"); crate::logger::init().expect("failed to set logger");
log::info!("Initialising AKern {}", crate::VERSION); log::info!("Initialising AKern {}", crate::VERSION);
@ -64,12 +62,6 @@ unsafe extern "C" fn _kernel_start() -> ! {
) )
} }
/// Format args to serial console
pub fn serial_fmt(args: core::fmt::Arguments<'_>) -> core::fmt::Result {
use core::fmt::Write;
x86_64::instructions::interrupts::without_interrupts(|| SERIAL_CONSOLE.lock().write_fmt(args))
}
/// Spin loop /// Spin loop
pub fn sloop() -> ! { pub fn sloop() -> ! {
loop { loop {

View file

@ -30,12 +30,12 @@ pub const VERSION: Version = Version {
#[panic_handler] #[panic_handler]
fn panic(info: &core::panic::PanicInfo) -> ! { fn panic(info: &core::panic::PanicInfo) -> ! {
// TODO: Better panic handler // TODO: Better panic handler
let _ = crate::arch::serial_fmt(format_args!( let _ = crate::arch::log(format_args!(
"\x1b[1m\x1b[4m\x1b[38;5;125mKernel Panic\x1b[0m\r\n", "\x1b[1m\x1b[4m\x1b[38;5;125mKernel Panic\x1b[0m\r\n",
)); ));
if let Some(loc) = info.location() { if let Some(loc) = info.location() {
let _ = crate::arch::serial_fmt(format_args!( let _ = crate::arch::log(format_args!(
"Location: {}: {}, {}\r\n", "Location: {}: {}, {}\r\n",
loc.file(), loc.file(),
loc.line(), loc.line(),
@ -44,7 +44,7 @@ fn panic(info: &core::panic::PanicInfo) -> ! {
} }
if let Some(msg) = info.message() { if let Some(msg) = info.message() {
let _ = crate::arch::serial_fmt(format_args!("{msg}\r\n")); let _ = crate::arch::log(format_args!("{msg}\r\n"));
} }
loop {} loop {}

View file

@ -14,7 +14,7 @@ impl log::Log for Logger {
fn log(&self, record: &log::Record) { fn log(&self, record: &log::Record) {
let lvl = record.level(); let lvl = record.level();
crate::arch::serial_fmt(format_args!( crate::arch::log(format_args!(
"\x1b[38;5;{}m{lvl}\x1b[0m [{}]: {}\r\n", "\x1b[38;5;{}m{lvl}\x1b[0m [{}]: {}\r\n",
match lvl { match lvl {
Level::Error => "160", Level::Error => "160",