Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feat(kernel/vm): allocate virtual memory spot #165

Merged
merged 56 commits into from
Dec 15, 2024
Merged
Changes from 1 commit
Commits
Show all changes
56 commits
Select commit Hold shift + click to select a range
0d7947e
refactor: use xmas-elf instead of object
JonasKruckenberg Nov 23, 2024
82903c1
refactor(loader): remove `alloc` dependency
JonasKruckenberg Nov 23, 2024
03351d3
refactor: remove `panic-abort` crate
JonasKruckenberg Nov 23, 2024
a015e07
refactor: remove `elf` feature from kmm and move into loader
JonasKruckenberg Nov 23, 2024
15877be
cleanup
JonasKruckenberg Nov 24, 2024
9b59ea8
wip
JonasKruckenberg Nov 27, 2024
42bb36a
feat: `Riscv64Sv39::from_active`
JonasKruckenberg Nov 28, 2024
a7bf4dc
feat(sync): `Once::try_call_once`
JonasKruckenberg Nov 28, 2024
57f3bf2
chore: debug printing for page tables
JonasKruckenberg Nov 28, 2024
34a39d7
chore: bring back kernel parsing
JonasKruckenberg Nov 28, 2024
95aba25
refactor(loader): use `pmm` for memory management
JonasKruckenberg Dec 6, 2024
c3a52ff
refactor: cleanup kernel for refactor
JonasKruckenberg Dec 6, 2024
09fa1b8
refactor: reduce memory size for QEMU
JonasKruckenberg Dec 6, 2024
7687068
remove kmm
JonasKruckenberg Dec 7, 2024
532c1f3
Merge branch 'main' into new-vm2
JonasKruckenberg Dec 7, 2024
60d940c
fmt & fixes
JonasKruckenberg Dec 7, 2024
0c5ffe7
cleanup
JonasKruckenberg Dec 10, 2024
071001d
feat(loader): allocate & map kernel heap
JonasKruckenberg Dec 10, 2024
d52cf83
wip
JonasKruckenberg Dec 10, 2024
33097ee
fix(loader): correctly report memory regions ptr and len
JonasKruckenberg Dec 11, 2024
ed7de8a
wip(wavltree): impl Send and Sync for tree
JonasKruckenberg Dec 11, 2024
f4ec629
fmt
JonasKruckenberg Dec 11, 2024
5e417bd
refactor: move `vmm` crate into kernel
JonasKruckenberg Dec 11, 2024
5abeeed
wip
JonasKruckenberg Dec 11, 2024
d55558a
refactor(pmm): remove overengineered arch trait
JonasKruckenberg Dec 12, 2024
ae5e4ab
wavltree fixes
JonasKruckenberg Dec 12, 2024
4307fa3
cleanup
JonasKruckenberg Dec 12, 2024
e5c0581
fmt
JonasKruckenberg Dec 12, 2024
51c38a1
Merge branch 'main' into new-vm2
JonasKruckenberg Dec 12, 2024
21029ae
Merge branch 'main' into new-vm2
JonasKruckenberg Dec 12, 2024
470dcd6
Update once.rs
JonasKruckenberg Dec 12, 2024
102c70c
Merge branch 'main' into new-vm2
JonasKruckenberg Dec 12, 2024
7a1a735
cleanup
JonasKruckenberg Dec 12, 2024
f602dd3
refactor: report FDT memory region through `BootInfo.memory_regions` …
JonasKruckenberg Dec 12, 2024
b2610e7
cleanup
JonasKruckenberg Dec 12, 2024
7a623b6
fix: report FDT through memory regions array
JonasKruckenberg Dec 12, 2024
a144dcd
fix: correctly handle unmapping
JonasKruckenberg Dec 12, 2024
2f2de68
clippy
JonasKruckenberg Dec 12, 2024
12ad8bd
fix: use virtual FDT address is test runner
JonasKruckenberg Dec 12, 2024
ae78433
refactor: rename `AddressSpace:: phys_offset` to `AddressSpace:: phys…
JonasKruckenberg Dec 12, 2024
62d6be3
docs
JonasKruckenberg Dec 12, 2024
a38bb24
fmt
JonasKruckenberg Dec 12, 2024
2456619
feat(wavltree): implement lifecycle hooks
JonasKruckenberg Dec 13, 2024
ac66b51
feat(kernel/vm): implement efficient gap search state
JonasKruckenberg Dec 13, 2024
7d3a63c
feat(kernel/vm): use prng for ASLR
JonasKruckenberg Dec 13, 2024
0e7f7ae
refactor: remove ambiguous and broken `cursor`/`cursor_mut` in favor …
JonasKruckenberg Dec 12, 2024
a91258b
chore(wavltree): release v0.0.1 (#161)
github-actions[bot] Dec 12, 2024
3976974
chore(deps): update rust crate target-lexicon to 0.13.0 (#157)
renovate[bot] Dec 12, 2024
590938a
feat(kernel): parse FDT on startup
JonasKruckenberg Dec 13, 2024
4f9616f
fix: seed ASLR prng from provided seed
JonasKruckenberg Dec 13, 2024
7401f98
feat(kernel/vm): allocate virtual memory spot
JonasKruckenberg Dec 13, 2024
10be9a9
wip: test the pick_spot impl
JonasKruckenberg Dec 13, 2024
d35d64c
clippy & fmt
JonasKruckenberg Dec 14, 2024
88a3941
refactor: move find_spot tests into tests
JonasKruckenberg Dec 14, 2024
6a0c727
fmt
JonasKruckenberg Dec 14, 2024
077ed06
update from main
JonasKruckenberg Dec 15, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
docs
  • Loading branch information
JonasKruckenberg committed Dec 12, 2024
commit 62d6be3522230c8edfc9e880a807d49e9206941e
86 changes: 61 additions & 25 deletions libs/pmm/src/address_space.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ pub struct AddressSpace {
}

impl AddressSpace {
/// Create a new address space with a fresh hardware page table.
pub fn new(
frame_alloc: &mut dyn FrameAllocator,
asid: usize,
Expand All @@ -28,6 +29,7 @@ impl AddressSpace {
Ok((this, Flush::empty(asid)))
}

/// Create an address space from the currently active hardware page table.
pub fn from_active(asid: usize, phys_offset: VirtualAddress) -> (Self, Flush) {
let root_pgtable = arch::get_active_pgtable(asid);
debug_assert!(root_pgtable.as_raw() != 0);
Expand All @@ -41,6 +43,7 @@ impl AddressSpace {
(this, Flush::empty(asid))
}

/// Return the physical address of the hardware page table root.
pub fn root_pgtable(&self) -> PhysicalAddress {
self.root_pgtable
}
Expand All @@ -50,14 +53,50 @@ impl AddressSpace {
self.phys_offset
}

/// Convert a physical address to a virtual address in this address space
pub fn phys_to_virt(&self, phys: PhysicalAddress) -> VirtualAddress {
self.phys_offset.add(phys.as_raw())
}

/// Return the address space identifier (ASID) of this address space
pub fn asid(&self) -> usize {
self.asid
}

/// Map an iterator of possibly non-contiguous physical frames into virtual memory starting
/// at `virt`. The size of the mapping is determined by the sum of the sizes of the frame regions.
///
/// Note that this function expects the virtual memory to be unmapped, to remap an already mapped
/// region use [`self.remap`].
pub fn map(
&mut self,
mut virt: VirtualAddress,
mut frames: NonContiguousFrames,
flags: crate::Flags,
flush: &mut Flush,
) -> crate::Result<()> {
while let Some((phys, len)) = frames.next().transpose()? {
self.map_contiguous(
frames.alloc_mut(),
virt,
phys,
NonZeroUsize::new(len.get() * arch::PAGE_SIZE).unwrap(),
flags,
flush,
)?;
virt = virt.add(len.get() * arch::PAGE_SIZE);
}

Ok(())
}

/// Map a contiguous run of physical frames of length `len` into virtual memory at `virt`.
///
/// Unless you absolutely require the physical frames to be contiguous, you should use [`self.map`]
/// instead.
///
/// Note that this function expects the virtual memory to be unmapped, to remap an already mapped
/// region use [`self.remap_contiguous`].
pub fn map_contiguous(
&mut self,
frame_alloc: &mut dyn FrameAllocator,
Expand Down Expand Up @@ -139,20 +178,22 @@ impl AddressSpace {
Ok(())
}

pub fn map(
/// Remap an iterator of possibly non-contiguous physical frames into virtual memory starting
/// at `virt`. The size of the mapping is determined by the sum of the sizes of the frame regions.
///
/// This function is similar to [`self.map`], but it expects the virtual memory to be already mapped
/// and simply changes the address of the backing frames.
pub fn remap(
&mut self,
mut virt: VirtualAddress,
mut iter: NonContiguousFrames,
flags: crate::Flags,
flush: &mut Flush,
) -> crate::Result<()> {
while let Some((phys, len)) = iter.next().transpose()? {
self.map_contiguous(
iter.alloc_mut(),
self.remap_contiguous(
virt,
phys,
NonZeroUsize::new(len.get() * arch::PAGE_SIZE).unwrap(),
flags,
flush,
)?;
virt = virt.add(len.get() * arch::PAGE_SIZE);
Expand All @@ -161,6 +202,13 @@ impl AddressSpace {
Ok(())
}

/// Remap a contiguous run of physical frames of length `len` into virtual memory at `virt`.
///
/// Unless you absolutely require the physical frames to be contiguous, you should use [`self.remap`]
/// instead.
///
/// This function is similar to [`self.map_contiguous`], but it expects the virtual memory to be already mapped
/// and simply changes the address of the backing frames.
pub fn remap_contiguous(
&mut self,
mut virt: VirtualAddress,
Expand Down Expand Up @@ -223,25 +271,10 @@ impl AddressSpace {
Ok(())
}

pub fn remap(
&mut self,
mut virt: VirtualAddress,
mut iter: NonContiguousFrames,
flush: &mut Flush,
) -> crate::Result<()> {
while let Some((phys, len)) = iter.next().transpose()? {
self.remap_contiguous(
virt,
phys,
NonZeroUsize::new(len.get() * arch::PAGE_SIZE).unwrap(),
flush,
)?;
virt = virt.add(len.get() * arch::PAGE_SIZE);
}

Ok(())
}

/// Change the permissions of a range of virtual memory starting at `virt` and of length
/// `len` to `new_flags`.
///
/// Note that you can only **reduce** permissions with this function, never increase them.
pub fn protect(
&mut self,
mut virt: VirtualAddress,
Expand Down Expand Up @@ -279,7 +312,7 @@ impl AddressSpace {
let (phys, old_flags) = pte.get_address_and_flags();

// TODO replace this with an error
debug_assert!(old_flags.intersection(rwx_mask).contains(new_flags));
assert!(old_flags.intersection(rwx_mask).contains(new_flags));

pte.replace_address_and_flags(
phys,
Expand All @@ -303,6 +336,8 @@ impl AddressSpace {
Ok(())
}

/// Unmap a range of virtual memory starting at `virt` and of length `len`, this will also
/// free the physical frames backing the virtual memory and page table entries.
pub fn unmap(
&mut self,
frame_alloc: &mut dyn FrameAllocator,
Expand Down Expand Up @@ -376,6 +411,7 @@ impl AddressSpace {
Ok(())
}

/// Resolve a virtual address to its backing physical address and associated page table entry flags.
pub fn query(&mut self, virt: VirtualAddress) -> Option<(PhysicalAddress, crate::Flags)> {
let mut pgtable: NonNull<arch::PageTableEntry> =
self.pgtable_ptr_from_phys(self.root_pgtable);
Expand Down