Initialize ACPI tables
This commit is contained in:
parent
17c4d60c82
commit
0983b36cc7
4 changed files with 52 additions and 19 deletions
|
@ -1,4 +1,5 @@
|
||||||
use core::{
|
use core::{
|
||||||
|
arch::asm,
|
||||||
panic,
|
panic,
|
||||||
sync::atomic::{AtomicBool, Ordering},
|
sync::atomic::{AtomicBool, Ordering},
|
||||||
};
|
};
|
||||||
|
@ -40,6 +41,11 @@ fn _get_free_frame() -> u64 {
|
||||||
}
|
}
|
||||||
panic!("No free memory left");
|
panic!("No free memory left");
|
||||||
}
|
}
|
||||||
|
fn invlpg(addr: u64) {
|
||||||
|
unsafe {
|
||||||
|
asm!("invlpg [{}]", in(reg) addr);
|
||||||
|
}
|
||||||
|
}
|
||||||
fn virt_to_phys(virt: u64) -> u64 {
|
fn virt_to_phys(virt: u64) -> u64 {
|
||||||
if !PAGING_ACTIVE.load(Ordering::Relaxed) {
|
if !PAGING_ACTIVE.load(Ordering::Relaxed) {
|
||||||
return virt - KERNEL_HEAP_START + HEAP_PHYS_START.get().unwrap();
|
return virt - KERNEL_HEAP_START + HEAP_PHYS_START.get().unwrap();
|
||||||
|
@ -64,22 +70,25 @@ fn get_table_entry(table: &mut PageTable, i: usize) -> &mut PageTable {
|
||||||
}
|
}
|
||||||
return table.entries_virt[i].as_mut().unwrap();
|
return table.entries_virt[i].as_mut().unwrap();
|
||||||
}
|
}
|
||||||
fn get_page(pml4: &PageTable, virt: u64) -> Option<&PageEntry> {
|
fn get_page(pml4: &mut PageTable, virt: u64) -> Option<&mut PageEntry> {
|
||||||
let virt_page = virt as usize / 0x1000;
|
let virt_page = virt as usize / 0x1000;
|
||||||
let table_i = virt_page % 512;
|
let table_i = virt_page % 512;
|
||||||
let directory_i = virt_page / 512 % 512;
|
let directory_i = virt_page / 512 % 512;
|
||||||
let pdpt_i = virt_page / 512 / 512 % 512;
|
let pdpt_i = virt_page / 512 / 512 % 512;
|
||||||
let pml4_i = virt_page / 512 / 512 / 512 % 512;
|
let pml4_i = virt_page / 512 / 512 / 512 % 512;
|
||||||
let pdpt = &pml4.entries_virt[pml4_i];
|
let pdpt = &mut pml4.entries_virt[pml4_i];
|
||||||
if pdpt.is_some() {
|
if pdpt.is_some() {
|
||||||
let pdpt = pdpt.as_ref().unwrap();
|
let pdpt = pdpt.as_mut().unwrap();
|
||||||
let directory = &pdpt.entries_virt[pdpt_i];
|
let directory = &mut pdpt.entries_virt[pdpt_i];
|
||||||
if directory.is_some() {
|
if directory.is_some() {
|
||||||
let directory = directory.as_ref().unwrap();
|
let directory = directory.as_mut().unwrap();
|
||||||
let table = &directory.entries_virt[directory_i];
|
let table = &mut directory.entries_virt[directory_i];
|
||||||
if table.is_some() {
|
if table.is_some() {
|
||||||
let table = table.as_ref().unwrap();
|
let table = table.as_mut().unwrap();
|
||||||
return Some(&table.entries_phys[table_i]);
|
if table.entries_phys[table_i].present() == 0 {
|
||||||
|
return None;
|
||||||
|
}
|
||||||
|
return Some(&mut table.entries_phys[table_i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -125,6 +134,19 @@ fn map(pml4: &mut PageTable, virt: u64, phys: u64, user: bool, write: bool, exec
|
||||||
table.entries_phys[table_i].set_execute_disable(!exec as u64);
|
table.entries_phys[table_i].set_execute_disable(!exec as u64);
|
||||||
table.entries_phys[table_i].set_present(1);
|
table.entries_phys[table_i].set_present(1);
|
||||||
}
|
}
|
||||||
|
pub unsafe fn unmap(address: u64) {
|
||||||
|
let mut current_pml4 = CURRENT_PML4.lock();
|
||||||
|
let page = get_page(current_pml4.as_mut().unwrap(), address);
|
||||||
|
assert!(page.is_some(), "Page isn't mapped");
|
||||||
|
match page {
|
||||||
|
Some(page) => {
|
||||||
|
page.set_present(0);
|
||||||
|
page.set_address(0);
|
||||||
|
invlpg(address);
|
||||||
|
}
|
||||||
|
None => {}
|
||||||
|
}
|
||||||
|
}
|
||||||
pub unsafe fn map_range(virt_start: u64, phys_start: u64, size: u64, user: bool, write: bool, exec: bool) {
|
pub unsafe fn map_range(virt_start: u64, phys_start: u64, size: u64, user: bool, write: bool, exec: bool) {
|
||||||
assert_eq!(virt_start % 0x1000, 0);
|
assert_eq!(virt_start % 0x1000, 0);
|
||||||
assert_eq!(phys_start % 0x1000, 0);
|
assert_eq!(phys_start % 0x1000, 0);
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
|
|
||||||
extern crate alloc;
|
extern crate alloc;
|
||||||
|
|
||||||
use core::{arch::global_asm, mem::MaybeUninit, panic::PanicInfo};
|
use core::{arch::global_asm, mem::MaybeUninit, panic::PanicInfo, ptr::null_mut};
|
||||||
|
|
||||||
use cpu::{gdt::setup_gdt, idt::setup_idt, paging::setup_paging};
|
use cpu::{gdt::setup_gdt, idt::setup_idt, paging::setup_paging};
|
||||||
use kernel_common::{
|
use kernel_common::{
|
||||||
|
@ -15,7 +15,7 @@ use kernel_common::{
|
||||||
use linked_list_allocator::LockedHeap;
|
use linked_list_allocator::LockedHeap;
|
||||||
use log::{error, info};
|
use log::{error, info};
|
||||||
use spin::Once;
|
use spin::Once;
|
||||||
use sys::pic::disable_pic;
|
use sys::{acpica::AcpiInitializeTables, pic::disable_pic};
|
||||||
|
|
||||||
mod cpu;
|
mod cpu;
|
||||||
mod misc;
|
mod misc;
|
||||||
|
@ -45,6 +45,9 @@ extern "C" fn main(temp_loader_struct: *const LoaderStruct) -> ! {
|
||||||
setup_paging(&loader_struct, loader_struct.phys_kernel_start, loader_struct.phys_heap_start);
|
setup_paging(&loader_struct, loader_struct.phys_kernel_start, loader_struct.phys_heap_start);
|
||||||
disable_pic();
|
disable_pic();
|
||||||
RSDP_ADDRESS.call_once(|| loader_struct.rsdp_address);
|
RSDP_ADDRESS.call_once(|| loader_struct.rsdp_address);
|
||||||
|
unsafe {
|
||||||
|
AcpiInitializeTables(null_mut(), 16, 0);
|
||||||
|
}
|
||||||
loop {
|
loop {
|
||||||
hlt();
|
hlt();
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,12 +7,12 @@ use core::{
|
||||||
use kernel_common::log::log_raw;
|
use kernel_common::log::log_raw;
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
cpu::paging::{find_free_virt_range, map_range, KERNEL_MAPPINGS_END, KERNEL_MAPPINGS_START},
|
cpu::paging::{find_free_virt_range, map_range, unmap, KERNEL_MAPPINGS_END, KERNEL_MAPPINGS_START},
|
||||||
misc::wrapped_alloc::{wrapped_alloc, wrapped_dealloc},
|
misc::wrapped_alloc::{wrapped_alloc, wrapped_dealloc},
|
||||||
RSDP_ADDRESS,
|
RSDP_ADDRESS,
|
||||||
};
|
};
|
||||||
|
|
||||||
use super::acpica::{ACPI_PHYSICAL_ADDRESS, ACPI_PREDEFINED_NAMES, ACPI_SIZE, ACPI_STATUS, ACPI_STRING, ACPI_TABLE_HEADER, UINT32};
|
use super::acpica::{ACPI_PHYSICAL_ADDRESS, ACPI_PREDEFINED_NAMES, ACPI_SIZE, ACPI_STATUS, ACPI_STRING, ACPI_TABLE_HEADER, UINT32, UINT64};
|
||||||
|
|
||||||
pub const AE_OK: ACPI_STATUS = 0;
|
pub const AE_OK: ACPI_STATUS = 0;
|
||||||
|
|
||||||
|
@ -58,8 +58,8 @@ extern "C" fn AcpiOsGetRootPointer() -> ACPI_PHYSICAL_ADDRESS {
|
||||||
*RSDP_ADDRESS.get().unwrap()
|
*RSDP_ADDRESS.get().unwrap()
|
||||||
}
|
}
|
||||||
#[no_mangle]
|
#[no_mangle]
|
||||||
extern "C" fn AcpiOsGetThreadId() {
|
extern "C" fn AcpiOsGetThreadId() -> UINT64 {
|
||||||
panic!("Unimplemented");
|
1
|
||||||
}
|
}
|
||||||
#[no_mangle]
|
#[no_mangle]
|
||||||
extern "C" fn AcpiOsGetTimer() {
|
extern "C" fn AcpiOsGetTimer() {
|
||||||
|
@ -148,8 +148,16 @@ extern "C" fn AcpiOsTerminate() -> ACPI_STATUS {
|
||||||
AE_OK
|
AE_OK
|
||||||
}
|
}
|
||||||
#[no_mangle]
|
#[no_mangle]
|
||||||
extern "C" fn AcpiOsUnmapMemory() {
|
extern "C" fn AcpiOsUnmapMemory(address: *mut c_void, size: ACPI_SIZE) {
|
||||||
panic!("Unimplemented");
|
let address = address as u64;
|
||||||
|
let end = (address + size + 0xfff) / 0x1000 * 0x1000;
|
||||||
|
let start = address / 0x1000 * 0x1000;
|
||||||
|
let size = end - start;
|
||||||
|
for i in 0..size / 0x1000 {
|
||||||
|
unsafe {
|
||||||
|
unmap(start + i * 0x1000);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
#[no_mangle]
|
#[no_mangle]
|
||||||
extern "C" fn AcpiOsPrint(raw_str: *const c_char) {
|
extern "C" fn AcpiOsPrint(raw_str: *const c_char) {
|
||||||
|
|
6
loader/Cargo.lock
generated
6
loader/Cargo.lock
generated
|
@ -123,9 +123,9 @@ dependencies = [
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "syn"
|
name = "syn"
|
||||||
version = "2.0.69"
|
version = "2.0.70"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "201fcda3845c23e8212cd466bfebf0bd20694490fc0356ae8e428e0824a915a6"
|
checksum = "2f0209b68b3613b093e0ec905354eccaedcfe83b8cb37cbdeae64026c3064c16"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"proc-macro2",
|
"proc-macro2",
|
||||||
"quote",
|
"quote",
|
||||||
|
@ -165,7 +165,7 @@ checksum = "4f345e42323c05e41e29e409505f5f8e0df7b5743340215d60344dbd79b729f4"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"proc-macro2",
|
"proc-macro2",
|
||||||
"quote",
|
"quote",
|
||||||
"syn 2.0.69",
|
"syn 2.0.70",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
|
|
Loading…
Add table
Reference in a new issue