2022-12-19 11:33:07 +02:00
|
|
|
#pragma once
|
|
|
|
|
2023-01-23 20:13:57 +02:00
|
|
|
#include <BAN/Vector.h>
|
|
|
|
#include <kernel/InterruptController.h>
|
2023-07-05 23:41:35 +03:00
|
|
|
#include <kernel/Memory/Types.h>
|
2022-12-19 11:33:07 +02:00
|
|
|
|
2023-10-05 18:53:45 +03:00
|
|
|
namespace Kernel
|
2022-12-19 11:33:07 +02:00
|
|
|
{
|
2023-10-05 18:53:45 +03:00
|
|
|
|
|
|
|
class APIC final : public InterruptController
|
2023-01-23 20:13:57 +02:00
|
|
|
{
|
2023-10-05 18:53:45 +03:00
|
|
|
public:
|
|
|
|
virtual void eoi(uint8_t) override;
|
|
|
|
virtual void enable_irq(uint8_t) override;
|
|
|
|
virtual bool is_in_service(uint8_t) override;
|
|
|
|
|
2024-01-13 17:11:26 +02:00
|
|
|
virtual BAN::ErrorOr<void> reserve_irq(uint8_t irq) override;
|
|
|
|
virtual BAN::Optional<uint8_t> get_free_irq() override;
|
|
|
|
|
2023-10-05 18:53:45 +03:00
|
|
|
private:
|
|
|
|
uint32_t read_from_local_apic(ptrdiff_t);
|
|
|
|
void write_to_local_apic(ptrdiff_t, uint32_t);
|
|
|
|
|
|
|
|
private:
|
|
|
|
~APIC() { ASSERT_NOT_REACHED(); }
|
|
|
|
static APIC* create();
|
|
|
|
friend class InterruptController;
|
|
|
|
|
|
|
|
private:
|
|
|
|
struct Processor
|
2023-01-23 20:13:57 +02:00
|
|
|
{
|
2023-10-05 18:53:45 +03:00
|
|
|
enum Flags : uint8_t
|
|
|
|
{
|
|
|
|
Enabled = 1,
|
|
|
|
OnlineCapable = 2,
|
|
|
|
};
|
|
|
|
uint8_t processor_id;
|
|
|
|
uint8_t apic_id;
|
|
|
|
uint8_t flags;
|
2023-01-23 20:13:57 +02:00
|
|
|
};
|
|
|
|
|
2023-10-05 18:53:45 +03:00
|
|
|
struct IOAPIC
|
|
|
|
{
|
|
|
|
uint8_t id;
|
|
|
|
Kernel::paddr_t paddr;
|
|
|
|
Kernel::vaddr_t vaddr;
|
|
|
|
uint32_t gsi_base;
|
|
|
|
uint8_t max_redirs;
|
|
|
|
|
|
|
|
uint32_t read(uint8_t offset);
|
|
|
|
void write(uint8_t offset, uint32_t data);
|
|
|
|
};
|
|
|
|
|
|
|
|
private:
|
|
|
|
BAN::Vector<Processor> m_processors;
|
|
|
|
Kernel::paddr_t m_local_apic_paddr = 0;
|
|
|
|
Kernel::vaddr_t m_local_apic_vaddr = 0;
|
2024-01-24 14:43:46 +02:00
|
|
|
BAN::Vector<IOAPIC> m_io_apics;
|
2023-10-05 18:53:45 +03:00
|
|
|
uint8_t m_irq_overrides[0x100] {};
|
2024-01-13 17:11:26 +02:00
|
|
|
uint8_t m_reserved_gsis[0x100 / 8] {};
|
2023-01-23 20:13:57 +02:00
|
|
|
};
|
|
|
|
|
2023-10-05 18:53:45 +03:00
|
|
|
}
|