// SPDX-License-Identifier: MIT OR Apache-2.0 // // Copyright (c) 2018-2022 Andre Richter //! A panic handler that infinitely waits. use crate::{bsp, cpu}; use core::{fmt, panic::PanicInfo}; //-------------------------------------------------------------------------------------------------- // Private Code //-------------------------------------------------------------------------------------------------- fn _panic_print(args: fmt::Arguments) { use fmt::Write; unsafe { bsp::console::panic_console_out().write_fmt(args).unwrap() }; } /// Prints with a newline - only use from the panic handler. /// /// Carbon copy from #[macro_export] macro_rules! panic_println { ($($arg:tt)*) => ({ _panic_print(format_args_nl!($($arg)*)); }) } #[panic_handler] fn panic(info: &PanicInfo) -> ! { use crate::time::interface::TimeManager; let timestamp = crate::time::time_manager().uptime(); if let Some(args) = info.message() { panic_println!( "[ {:>3}.{:06}] Kernel panic: {}", timestamp.as_secs(), timestamp.subsec_micros(), args, ); } else { panic_println!( "[ {:>3}.{:06}] Kernel panic!", timestamp.as_secs(), timestamp.subsec_micros(), ); } cpu::wait_forever() }