/* * Copyright (c) 2020, Liav A. * * SPDX-License-Identifier: BSD-2-Clause */ #pragma once #include #include #include #include #include #include #include #include #include namespace Kernel { class ISAInterruptOverrideMetadata { public: ISAInterruptOverrideMetadata(u8 bus, u8 source, u32 global_system_interrupt, u16 flags) : m_bus(bus) , m_source(source) , m_global_system_interrupt(global_system_interrupt) , m_flags(flags) { } u8 bus() const { return m_bus; } u8 source() const { return m_source; } u32 gsi() const { return m_global_system_interrupt; } u16 flags() const { return m_flags; } private: u8 const m_bus; u8 const m_source; u32 const m_global_system_interrupt; u16 const m_flags; }; class InterruptManagement { public: static InterruptManagement& the(); static void initialize(); static bool initialized(); static u8 acquire_mapped_interrupt_number(u8 original_irq); static u8 acquire_irq_number(u8 mapped_interrupt_vector); void switch_to_pic_mode(); void switch_to_ioapic_mode(); NonnullLockRefPtr get_responsible_irq_controller(u8 interrupt_vector); NonnullLockRefPtr get_responsible_irq_controller(IRQControllerType controller_type, u8 interrupt_vector); Vector const& isa_overrides() const { return m_isa_interrupt_overrides; } u8 get_mapped_interrupt_vector(u8 original_irq); u8 get_irq_vector(u8 mapped_interrupt_vector); void enumerate_interrupt_handlers(Function); IRQController& get_interrupt_controller(size_t index); protected: virtual ~InterruptManagement() = default; private: InterruptManagement(); ErrorOr> find_madt_physical_address(); void locate_apic_data(); Vector> m_interrupt_controllers; Vector m_isa_interrupt_overrides; Vector m_pci_interrupt_overrides; Optional m_madt_physical_address; }; }