Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
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
5 changes: 3 additions & 2 deletions litebox/src/platform/page_mgmt.rs
Original file line number Diff line number Diff line change
Expand Up @@ -135,20 +135,21 @@ pub trait PageManagementProvider<const ALIGN: usize>: RawPointerProvider {
let total_len = old_range.len();
let mut offset = 0;
while offset < total_len {
let chunk_len = (total_len - offset).min(ALIGN);
let old_ptr =
<Self as RawPointerProvider>::RawConstPointer::from_usize(old_range.start + offset);
new_ptr
.write_slice_at_offset(
isize::try_from(offset).unwrap(),
&old_ptr.to_owned_slice(old_range.len()).unwrap(),
&old_ptr.to_owned_slice(chunk_len).unwrap(),
)
.unwrap();
offset += ALIGN;
}

if temp_permissions != permissions {
(unsafe { self.update_permissions(new_range.clone(), permissions) })
.expect("failed to restore perrmissions on new range");
.expect("failed to restore permissions on new range");
}

(unsafe { self.deallocate_pages(old_range) }).expect("failed to deallocate old range");
Expand Down
10 changes: 2 additions & 8 deletions litebox_common_linux/src/mm.rs
Original file line number Diff line number Diff line change
Expand Up @@ -20,12 +20,6 @@ fn align_up(addr: usize, align: usize) -> usize {
(addr + align - 1) & !(align - 1)
}

#[inline]
fn align_down(addr: usize, align: usize) -> usize {
debug_assert!(align.is_power_of_two());
addr & !(align - 1)
}

pub fn do_mmap<
Platform: litebox::platform::RawPointerProvider
+ litebox::sync::RawSyncPrimitivesProvider
Expand Down Expand Up @@ -184,8 +178,8 @@ pub fn sys_mremap<
return Err(Errno::EINVAL);
}

let old_size = align_down(old_size, PAGE_SIZE);
let new_size = align_down(new_size, PAGE_SIZE);
let old_size = align_up(old_size, PAGE_SIZE);
let new_size = align_up(new_size, PAGE_SIZE);
if new_size == 0 {
return Err(Errno::EINVAL);
}
Expand Down
2 changes: 1 addition & 1 deletion litebox_platform_linux_kernel/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -459,7 +459,7 @@ impl<Host: HostInterface, const ALIGN: usize> PageManagementProvider<ALIGN> for
.ok_or(litebox::platform::page_mgmt::RemapError::Unaligned)?;
let new_range = PageRange::new(new_range.start, new_range.end)
.ok_or(litebox::platform::page_mgmt::RemapError::Unaligned)?;
if old_range.start.max(new_range.start) <= old_range.end.min(new_range.end) {
if old_range.start.max(new_range.start) < old_range.end.min(new_range.end) {
return Err(litebox::platform::page_mgmt::RemapError::Overlapping);
}
unsafe { self.page_table.remap_pages(old_range, new_range) }
Expand Down
Loading