Skip to content

Commit

Permalink
refactor(apic): migrate CR3 access to x86_64 crate
Browse files Browse the repository at this point in the history
  • Loading branch information
mkroening committed Dec 20, 2024
1 parent 083816e commit 270af2e
Showing 1 changed file with 7 additions and 4 deletions.
11 changes: 7 additions & 4 deletions src/arch/x86_64/kernel/apic.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,9 +15,9 @@ use arch::x86_64::kernel::core_local::*;
use arch::x86_64::kernel::{interrupts, processor};
use hermit_sync::{without_interrupts, OnceCell, SpinMutex};
use memory_addresses::{AddrRange, PhysAddr, VirtAddr};
#[cfg(feature = "smp")]
use x86::controlregs::*;
use x86::msr::*;
#[cfg(feature = "smp")]
use x86_64::registers::control::Cr3;
use x86_64::registers::model_specific::Msr;

use super::interrupts::IDT;
Expand Down Expand Up @@ -212,8 +212,9 @@ extern "x86-interrupt" fn tlb_flush_handler(stack_frame: interrupts::ExceptionSt
swapgs(&stack_frame);
debug!("Received TLB Flush Interrupt");
increment_irq_counter(TLB_FLUSH_INTERRUPT_NUMBER);
let (frame, val) = Cr3::read_raw();
unsafe {
cr3_write(cr3());
Cr3::write_raw(frame, val);
}
eoi();
swapgs(&stack_frame);
Expand Down Expand Up @@ -741,9 +742,11 @@ pub fn boot_application_processors() {
}

unsafe {
let (frame, val) = Cr3::read_raw();
let value = frame.start_address().as_u64() | u64::from(val);
// Pass the PML4 page table address to the boot code.
*((SMP_BOOT_CODE_ADDRESS + SMP_BOOT_CODE_OFFSET_PML4).as_mut_ptr::<u32>()) =
cr3().try_into().unwrap();
value.try_into().unwrap();
// Set entry point
debug!(
"Set entry point for application processor to {:p}",
Expand Down

0 comments on commit 270af2e

Please sign in to comment.