123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103 |
- use alloc::vec::Vec;
- #[derive(Debug)]
- pub struct IoApic {
- pub id: u8,
- /// The physical address at which to access this I/O APIC.
- pub address: u32,
- /// The global system interrupt number where this I/O APIC's inputs start.
- pub global_system_interrupt_base: u32,
- }
- #[derive(Debug)]
- pub struct NmiLine {
- pub processor: NmiProcessor,
- pub line: LocalInterruptLine,
- }
- /// Indicates which local interrupt line will be utilized by an external interrupt. Specifically,
- /// these lines directly correspond to their requisite LVT entries in a processor's APIC.
- #[derive(Debug, Clone, Copy, PartialEq, Eq)]
- pub enum LocalInterruptLine {
- Lint0,
- Lint1,
- }
- #[derive(Debug, Clone, Copy, PartialEq, Eq)]
- pub enum NmiProcessor {
- All,
- ProcessorUid(u32),
- }
- /// Polarity indicates what signal mode the interrupt line needs to be in to be considered 'active'.
- #[derive(Debug, Clone, Copy, PartialEq, Eq)]
- pub enum Polarity {
- SameAsBus,
- ActiveHigh,
- ActiveLow,
- }
- /// Trigger mode of an interrupt, describing how the interrupt is triggered.
- ///
- /// When an interrupt is `Edge` triggered, it is triggered exactly once, when the interrupt
- /// signal goes from its opposite polarity to its active polarity.
- ///
- /// For `Level` triggered interrupts, a continuous signal is emitted so long as the interrupt
- /// is in its active polarity.
- ///
- /// `SameAsBus`-triggered interrupts will utilize the same interrupt triggering as the system bus
- /// they communicate across.
- #[derive(Debug, Clone, Copy, PartialEq, Eq)]
- pub enum TriggerMode {
- SameAsBus,
- Edge,
- Level,
- }
- /// Describes a difference in the mapping of an ISA interrupt to how it's mapped in other interrupt
- /// models. For example, if a device is connected to ISA IRQ 0 and IOAPIC input 2, an override will
- /// appear mapping source 0 to GSI 2. Currently these will only be created for ISA interrupt
- /// sources.
- #[derive(Debug)]
- pub struct InterruptSourceOverride {
- pub isa_source: u8,
- pub global_system_interrupt: u32,
- pub polarity: Polarity,
- pub trigger_mode: TriggerMode,
- }
- /// Describes a Global System Interrupt that should be enabled as non-maskable. Any source that is
- /// non-maskable can not be used by devices.
- #[derive(Debug)]
- pub struct NmiSource {
- pub global_system_interrupt: u32,
- pub polarity: Polarity,
- pub trigger_mode: TriggerMode,
- }
- #[derive(Debug)]
- pub struct Apic {
- pub local_apic_address: u64,
- pub io_apics: Vec<IoApic>,
- pub local_apic_nmi_lines: Vec<NmiLine>,
- pub interrupt_source_overrides: Vec<InterruptSourceOverride>,
- pub nmi_sources: Vec<NmiSource>,
- /// If this field is set, you must remap and mask all the lines of the legacy PIC, even if
- /// you choose to use the APIC. It's recommended that you do this even if ACPI does not
- /// require you to.
- pub also_has_legacy_pics: bool,
- }
- #[derive(Debug)]
- #[non_exhaustive]
- pub enum InterruptModel {
- /// This model is only chosen when the MADT does not describe another interrupt model. On `x86_64` platforms,
- /// this probably means only the legacy i8259 PIC is present.
- Unknown,
- /// Describes an interrupt controller based around the Advanced Programmable Interrupt Controller (any of APIC,
- /// XAPIC, or X2APIC). These are likely to be found on x86 and x86_64 systems and are made up of a Local APIC
- /// for each core and one or more I/O APICs to handle external interrupts.
- Apic(Apic),
- }
|