Skip to main content

PageTableRef

Struct PageTableRef 

Source
pub struct PageTableRef<T: TableMeta, A: FrameAllocator> {
    pub root: Frame<T, A>,
}

Fields§

§root: Frame<T, A>

Implementations§

Source§

impl<T: TableMeta, A: FrameAllocator> PageTableRef<T, A>

Source

pub unsafe fn new(allocator: A) -> PagingResult<Self>

创建一个新的页表

§Safety

调用者必须确保提供的FrameAllocator是有效的,并且在页表生命周期内保持有效

Source

pub fn from_paddr(paddr: PhysAddr, allocator: A) -> Self

Source

pub fn map(&mut self, config: &MapConfig) -> PagingResult

映射虚拟地址范围到物理地址范围

Source

pub fn unmap(&mut self, start_vaddr: VirtAddr, size: usize) -> PagingResult<()>

取消映射虚拟地址范围

§参数
  • start_vaddr: 要取消映射的起始虚拟地址
  • size: 要取消映射的大小(字节)
§返回值
  • Ok(()): 取消映射成功
  • Err(PagingError): 取消映射失败
§行为
  • 清除指定虚拟地址范围内的所有页表项
  • 自动回收空的子页表帧
  • 支持大页和普通页面的取消映射
  • 根据配置刷新TLB
Source

pub fn unmap_with_config(&mut self, config: &UnmapConfig) -> PagingResult<()>

使用配置对象取消映射

Source

pub fn walk_all(&self, config: WalkConfig) -> PageTableWalker<'_, T, A>

创建页表遍历迭代器

Source

pub fn walk( &self, start_vaddr: VirtAddr, end_vaddr: VirtAddr, ) -> impl Iterator<Item = PteInfo<T::P>> + '_

Source

pub fn walk_valid(&self) -> impl Iterator<Item = PteInfo<T::P>> + '_

遍历所有有效的最终映射页表项(过滤掉无效项和中间级别的页表指针)

Source

pub const fn page_size() -> usize

Source

pub const fn table_levels() -> usize

Source

pub const fn valid_bits() -> usize

Source

pub unsafe fn destroy(self)

销毁整个页表结构

此方法会:

  1. 递归释放根帧及所有子页表帧
  2. 清除所有页表项(设为invalid)
  3. 不释放映射的物理页(数据页/大页)
§Safety

调用者必须确保:

  • 没有其他代码在访问这个页表
  • 没有CPU正在使用这个页表进行地址翻译
  • 调用后不再使用这个PageTable实例
Source

pub unsafe fn deallocate(&mut self)

释放页表占用的所有页表帧

与destroy()不同,这个方法保留PageTable结构, 但释放所有关联的页表帧。调用后PageTable不再可用。

释放行为:

  • 释放所有页表帧
  • 清除所有页表项(设为invalid)
  • 不释放映射的物理页(数据页/大页)
§Safety

调用者必须确保:

  • 没有其他代码在访问这个页表
  • 没有CPU正在使用这个页表进行地址翻译
Source

pub fn deallocate_range( &mut self, start_vaddr: VirtAddr, end_vaddr: VirtAddr, ) -> PagingResult

释放页表中的指定映射区域

释放指定虚拟地址范围内的所有页表项和子页表帧 在释放前将相关PTE设为invalid

Source

pub fn translate(&self, vaddr: VirtAddr) -> PagingResult<(PhysAddr, T::P)>

通过虚拟地址查询页表项

§参数
  • vaddr: 要查询的虚拟地址
§返回值
  • Ok(T::P): 找到的页表项,包含物理地址信息
  • Err(PagingError): 查询失败,原因可能包括:
    • 地址未映射
    • 页表项无效
    • 页表层次结构错误
Source

pub fn translate_phys(&self, vaddr: VirtAddr) -> PagingResult<PhysAddr>

通过虚拟地址查询物理地址(便利方法)

§参数
  • vaddr: 要查询的虚拟地址
§返回值
  • Ok(PhysAddr): 找到的物理地址
  • Err(PagingError): 查询失败
Source

pub fn is_mapped(&self, vaddr: VirtAddr) -> bool

检查虚拟地址是否已映射

这是一个便利方法,用于快速检查地址是否已映射而不需要获取页表项

§参数
  • vaddr: 要检查的虚拟地址
§返回值
  • true: 地址已映射
  • false: 地址未映射
Source

pub fn root_paddr(&self) -> PhysAddr

获取页表的根帧物理地址

Trait Implementations§

Source§

impl<T: Clone + TableMeta, A: Clone + FrameAllocator> Clone for PageTableRef<T, A>

Source§

fn clone(&self) -> PageTableRef<T, A>

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<T: TableMeta, A: FrameAllocator> Debug for PageTableRef<T, A>
where T::P: Debug,

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<T: TableMeta, A: FrameAllocator> PageTableOp for PageTableRef<T, A>

Source§

fn addr(&self) -> PhysAddr

Source§

fn map(&mut self, config: &MapConfig) -> PagingResult

Source§

fn unmap( &mut self, virt_start: VirtAddr, size: usize, ) -> Result<(), PagingError>

Source§

impl<T: Copy + TableMeta, A: Copy + FrameAllocator> Copy for PageTableRef<T, A>

Auto Trait Implementations§

§

impl<T, A> Freeze for PageTableRef<T, A>
where A: Freeze,

§

impl<T, A> RefUnwindSafe for PageTableRef<T, A>

§

impl<T, A> Send for PageTableRef<T, A>

§

impl<T, A> Sync for PageTableRef<T, A>

§

impl<T, A> Unpin for PageTableRef<T, A>
where A: Unpin, T: Unpin,

§

impl<T, A> UnwindSafe for PageTableRef<T, A>
where A: UnwindSafe, T: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.