From f7449c4ab91cdb9b5bc511863971e9823171a16e Mon Sep 17 00:00:00 2001 From: Bananymous Date: Thu, 10 Aug 2023 21:03:25 +0300 Subject: [PATCH] Kernel: APIC now uses MMIO namespace functions for mmio --- kernel/kernel/APIC.cpp | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/kernel/kernel/APIC.cpp b/kernel/kernel/APIC.cpp index 537a1df6..c181d024 100644 --- a/kernel/kernel/APIC.cpp +++ b/kernel/kernel/APIC.cpp @@ -5,6 +5,7 @@ #include #include #include +#include #include @@ -194,26 +195,24 @@ APIC* APIC::create() uint32_t APIC::read_from_local_apic(ptrdiff_t offset) { - return *(uint32_t*)(m_local_apic_vaddr + offset); + return MMIO::read32(m_local_apic_vaddr + offset); } void APIC::write_to_local_apic(ptrdiff_t offset, uint32_t data) { - *(uint32_t*)(m_local_apic_vaddr + offset) = data; + MMIO::write32(m_local_apic_vaddr + offset, data); } uint32_t APIC::IOAPIC::read(uint8_t offset) { - volatile uint32_t* ioapic = (volatile uint32_t*)vaddr; - ioapic[0] = offset; - return ioapic[4]; + MMIO::write32(vaddr, offset); + return MMIO::read32(vaddr + 16); } void APIC::IOAPIC::write(uint8_t offset, uint32_t data) { - volatile uint32_t* ioapic = (volatile uint32_t*)vaddr; - ioapic[0] = offset; - ioapic[4] = data; + MMIO::write32(vaddr, offset); + MMIO::write32(vaddr + 16, data); } void APIC::eoi(uint8_t) @@ -239,6 +238,7 @@ void APIC::enable_irq(uint8_t irq) RedirectionEntry redir; redir.lo_dword = ioapic->read(IOAPIC_REDIRS + gsi * 2); redir.hi_dword = ioapic->read(IOAPIC_REDIRS + gsi * 2 + 1); + ASSERT(redir.mask); // TODO: handle overlapping interrupts redir.vector = IRQ_VECTOR_BASE + irq; redir.mask = 0;