mycelium_kernel::arch::interrupt::idt

Struct Idt

Source
#[repr(C, align(16))]
pub struct Idt { /* private fields */ }

Implementations§

Source§

impl Idt

Source

pub const NUM_VECTORS: usize = 256usize

Source

pub const DIVIDE_BY_ZERO: usize = 0usize

Divide-by-zero interrupt (#D0)

Source

pub const DEBUG: usize = 1usize

Source

pub const NMI: usize = 2usize

Non-maskable interrupt.

Source

pub const BREAKPOINT: usize = 3usize

Source

pub const OVERFLOW: usize = 4usize

Source

pub const BOUND_RANGE_EXCEEDED: usize = 5usize

Source

pub const INVALID_OPCODE: usize = 6usize

Source

pub const DEVICE_NOT_AVAILABLE: usize = 7usize

A device not available exception

Source

pub const DOUBLE_FAULT: usize = 8usize

Source

pub const COPROCESSOR_SEGMENT_OVERRUN: usize = 9usize

On modern CPUs, this interrupt is reserved; this error fires a general protection fault instead.

Source

pub const INVALID_TSS: usize = 10usize

Source

pub const SEGMENT_NOT_PRESENT: usize = 11usize

Source

pub const STACK_SEGMENT_FAULT: usize = 12usize

Source

pub const GENERAL_PROTECTION_FAULT: usize = 13usize

Source

pub const PAGE_FAULT: usize = 14usize

Source

pub const X87_FPU_EXCEPTION: usize = 16usize

Source

pub const ALIGNMENT_CHECK: usize = 17usize

Source

pub const MACHINE_CHECK: usize = 18usize

Source

pub const SIMD_FLOATING_POINT: usize = 19usize

Source

pub const VIRTUALIZATION_EXCEPTION: usize = 20usize

Source

pub const SECURITY_EXCEPTION: usize = 30usize

Source

pub const DOUBLE_FAULT_IST_OFFSET: usize = 4usize

Chosen by fair die roll, guaranteed to be random.

Source

pub const MAX_CPU_EXCEPTION: usize = 30usize

Source

pub const ISA_BASE: usize = 32usize

Base offset for ISA hardware interrupts.

Source

pub const LOCAL_APIC_TIMER: usize = 254usize

Local APIC timer interrupt vector mapped by Controller::enable_hardware_interrupts.

Systems which do not use that function to initialize the local APIC may map this interrupt to a different IDT vector.

Source

pub const LOCAL_APIC_SPURIOUS: usize = 255usize

Local APIC spurious interrupt vector mapped by Controller::enable_hardware_interrupts.

Systems which do not use that function to initialize the local APIC may map this interrupt to a different IDT vector.

Source

pub const PIC_BIG_START: usize = 32usize

Base of the primary PIC’s interrupt vector region mapped by Controller::enable_hardware_interrupts.

Systems which do not use that function to initialize the PICs may map this interrupt to a different IDT vector.

Source

pub const PIC_LITTLE_START: usize = 40usize

Base of the secondary PIC’s interrupt vector region mapped by Controller::enable_hardware_interrupts.

Systems which do not use that function to initialize the PICs may map this interrupt to a different IDT vector.

Source

pub const fn new() -> Idt

Source

pub fn register_isa_isr(&mut self, irq: IsaInterrupt, isr: *const ())

Register an interrupt service routine (ISR) for the given ISA standard PC interrupt.

Source

pub fn register_isr(&mut self, vector: usize, isr: *const ())

Source

pub fn load(&'static self)

Source

pub unsafe fn load_raw(&self)

§Safety

The referenced IDT must be valid for the 'static lifetime.

Trait Implementations§

Source§

impl Control for Idt

Source§

type Registers = Registers

Source§

unsafe fn disable(&mut self)

Disable all interrupts. Read more
Source§

unsafe fn enable(&mut self)

Enable all interrupts. Read more
Source§

fn is_enabled(&self) -> bool

Returns true if interrupts are enabled.
Source§

fn register_handlers<H>(&mut self) -> Result<(), RegistrationError>
where H: Handlers<Registers>,

Source§

fn enter_critical(&mut self) -> CriticalGuard<'_, Self>

Enter a critical section, returning a guard.
Source§

impl Debug for Idt

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
Source§

impl Default for Idt

Source§

fn default() -> Idt

Returns the “default value” for a type. Read more

Auto Trait Implementations§

§

impl Freeze for Idt

§

impl RefUnwindSafe for Idt

§

impl Send for Idt

§

impl Sync for Idt

§

impl Unpin for Idt

§

impl UnwindSafe for Idt

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Az for T

Source§

fn az<Dst>(self) -> Dst
where T: Cast<Dst>,

Casts the value.
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<Src, Dst> CastFrom<Src> for Dst
where Src: Cast<Dst>,

Source§

fn cast_from(src: Src) -> Dst

Casts the value.
Source§

impl<T> CheckedAs for T

Source§

fn checked_as<Dst>(self) -> Option<Dst>
where T: CheckedCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> CheckedCastFrom<Src> for Dst
where Src: CheckedCast<Dst>,

Source§

fn checked_cast_from(src: Src) -> Option<Dst>

Casts the value.
§

impl<T> Downcast for T
where T: Any,

§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Send + Sync>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> OverflowingAs for T

Source§

fn overflowing_as<Dst>(self) -> (Dst, bool)
where T: OverflowingCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> OverflowingCastFrom<Src> for Dst
where Src: OverflowingCast<Dst>,

Source§

fn overflowing_cast_from(src: Src) -> (Dst, bool)

Casts the value.
Source§

impl<T> SaturatingAs for T

Source§

fn saturating_as<Dst>(self) -> Dst
where T: SaturatingCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> SaturatingCastFrom<Src> for Dst
where Src: SaturatingCast<Dst>,

Source§

fn saturating_cast_from(src: Src) -> Dst

Casts the value.
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> UnwrappedAs for T

Source§

fn unwrapped_as<Dst>(self) -> Dst
where T: UnwrappedCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> UnwrappedCastFrom<Src> for Dst
where Src: UnwrappedCast<Dst>,

Source§

fn unwrapped_cast_from(src: Src) -> Dst

Casts the value.
§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
Source§

impl<T> WrappingAs for T

Source§

fn wrapping_as<Dst>(self) -> Dst
where T: WrappingCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> WrappingCastFrom<Src> for Dst
where Src: WrappingCast<Dst>,

Source§

fn wrapping_cast_from(src: Src) -> Dst

Casts the value.