#![no_std] #![no_main] #![feature(abi_x86_interrupt)] use core::panic::PanicInfo; use xe_os::serial_print; #[no_mangle] pub extern "C" fn _start() -> ! { serial_print!("stack_overflow... "); xe_os::gdt::init(); init_test_idt(); stack_overflow(); panic!("Execution continued after stack overflow"); } #[allow(unconditional_recursion)] fn stack_overflow() { stack_overflow(); } #[panic_handler] fn panic(info: &PanicInfo) -> ! { xe_os::test_panic_handler(info) } use lazy_static::lazy_static; use x86_64::structures::idt::InterruptDescriptorTable; lazy_static! { static ref TEST_IDT: InterruptDescriptorTable = { let mut idt = InterruptDescriptorTable::new(); unsafe { idt.double_fault .set_handler_fn(test_double_fault_handler) .set_stack_index(xe_os::gdt::DOUBLE_FAULT_IST_INDEX); } idt }; } use xe_os::{exit_qemu, QemuExitCode, serial_println}; use x86_64::structures::idt::InterruptStackFrame; extern "x86-interrupt" fn test_double_fault_handler( _stack_frame: &mut InterruptStackFrame, _error_code: u64, ) { serial_println!("[ok]"); exit_qemu(QemuExitCode::Success); loop {} } pub fn init_test_idt() { TEST_IDT.load(); }