You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
52 lines
1.1 KiB
52 lines
1.1 KiB
pub mod consts;
|
|
pub mod fast_syscall;
|
|
mod handler;
|
|
mod trapframe;
|
|
|
|
pub use self::handler::*;
|
|
pub use self::trapframe::*;
|
|
use crate::consts::KERNEL_OFFSET;
|
|
use crate::memory::phys_to_virt;
|
|
use apic::*;
|
|
|
|
#[inline(always)]
|
|
pub unsafe fn enable() {
|
|
x86_64::instructions::interrupts::enable();
|
|
}
|
|
|
|
#[inline(always)]
|
|
pub unsafe fn disable() {
|
|
x86_64::instructions::interrupts::disable();
|
|
}
|
|
|
|
#[inline(always)]
|
|
pub unsafe fn disable_and_store() -> usize {
|
|
let r: usize;
|
|
asm!("pushfq; popq $0; cli" : "=r"(r) :: "memory");
|
|
r
|
|
}
|
|
|
|
#[inline(always)]
|
|
pub unsafe fn restore(flags: usize) {
|
|
asm!("pushq $0; popfq" :: "r"(flags) : "memory" "flags");
|
|
}
|
|
|
|
#[inline(always)]
|
|
pub fn no_interrupt(f: impl FnOnce()) {
|
|
let flags = unsafe { disable_and_store() };
|
|
f();
|
|
unsafe { restore(flags) };
|
|
}
|
|
|
|
#[inline(always)]
|
|
pub fn enable_irq(irq: u8) {
|
|
let mut ioapic = unsafe { IoApic::new(phys_to_virt(IOAPIC_ADDR as usize)) };
|
|
ioapic.enable(irq, 0);
|
|
}
|
|
|
|
#[inline(always)]
|
|
pub fn ack(_irq: u8) {
|
|
let mut lapic = unsafe { XApic::new(phys_to_virt(LAPIC_ADDR)) };
|
|
lapic.eoi();
|
|
}
|