offset acpi and apic pointers to hhdm

This commit is contained in:
Zoe
2024-05-14 23:48:31 -05:00
parent 125b69bb51
commit cb5071aa25
2 changed files with 11 additions and 6 deletions

View File

@@ -1,4 +1,4 @@
use crate::{drivers::acpi::SMP_REQUEST, hcf, libs::cell::OnceCell};
use crate::{drivers::acpi::SMP_REQUEST, hcf, libs::cell::OnceCell, mem::HHDM_OFFSET};
use alloc::{sync::Arc, vec::Vec};
@@ -96,7 +96,7 @@ impl APIC {
crate::log_info!("MADT located at: {:p}", core::ptr::addr_of!(madt));
let mut lapic_ptr = madt.inner.local_apic_address as *mut u8;
let mut lapic_ptr = (madt.inner.local_apic_address as usize + *HHDM_OFFSET) as *mut u8;
let mut io_apic = None;
let mut io_apic_source_override = None;
@@ -117,7 +117,8 @@ impl APIC {
io_apic = Some(IOAPIC {
ioapic_id: core::ptr::read_unaligned(ptr.add(2)),
_reserved: core::ptr::read_unaligned(ptr.add(3)),
ptr: (core::ptr::read_unaligned(ptr.add(4).cast::<u32>())) as *mut u8,
ptr: (core::ptr::read_unaligned(ptr.add(4).cast::<u32>()) as usize
+ *HHDM_OFFSET) as *mut u8,
global_interrupt_base: core::ptr::read_unaligned(ptr.add(8).cast::<u32>()),
})
},
@@ -132,8 +133,9 @@ impl APIC {
})
},
5 => {
lapic_ptr =
unsafe { core::ptr::read_unaligned(ptr.add(4).cast::<u64>()) } as *mut u8
lapic_ptr = (unsafe { core::ptr::read_unaligned(ptr.add(4).cast::<u64>()) }
as usize
+ *HHDM_OFFSET) as *mut u8
}
_ => {}
}

View File

@@ -4,6 +4,7 @@ use limine::SmpRequest;
use crate::{
arch::io::{inw, outb},
libs::cell::OnceCell,
mem::HHDM_OFFSET,
};
pub static SMP_REQUEST: SmpRequest = SmpRequest::new(0);
@@ -31,7 +32,9 @@ pub struct SDT<'a, T> {
}
impl<'a, T> SDT<'a, T> {
unsafe fn new(ptr: *const u8) -> Self {
unsafe fn new(mut ptr: *const u8) -> Self {
ptr = ptr.add(*HHDM_OFFSET);
let length = core::ptr::read_unaligned(ptr.add(4).cast::<u32>());
let data = core::slice::from_raw_parts(ptr, length as usize);