#page-table #virtual-memory #paging #arceos

nightly no-std page_table_entry

Page table entry definition for various hardware architectures

12 releases (4 breaking)

0.5.0 Dec 17, 2024
0.4.2 Dec 17, 2024
0.4.1 Oct 10, 2024
0.4.0 Aug 27, 2024
0.1.2 Jul 17, 2024

#385 in Hardware support

Download history 330/week @ 2024-09-14 343/week @ 2024-09-21 200/week @ 2024-09-28 782/week @ 2024-10-05 1656/week @ 2024-10-12 1453/week @ 2024-10-19 439/week @ 2024-10-26 162/week @ 2024-11-02 399/week @ 2024-11-09 796/week @ 2024-11-16 572/week @ 2024-11-23 469/week @ 2024-11-30 541/week @ 2024-12-07 918/week @ 2024-12-14 786/week @ 2024-12-21 801/week @ 2024-12-28

3,128 downloads per month
Used in 3 crates

GPL-3.0-or-later OR Apache-2…

24KB
463 lines

page_table_entry

Crates.io Docs.rs CI

This crate provides the definition of page table entry for various hardware architectures.

Currently supported architectures and page table entry types:

All these types implement the GenericPTE trait, which provides unified methods for manipulating various page table entries.

Examples (x86_64)

use memory_addr::PhysAddr;
use x86_64::structures::paging::page_table::PageTableFlags;
use page_table_entry::{GenericPTE, MappingFlags, x86_64::X64PTE};

let paddr = PhysAddr::from(0x233000);
let pte = X64PTE::new_page(
    paddr,
    /* flags: */ MappingFlags::READ | MappingFlags::WRITE,
    /* is_huge: */ false,
);
assert!(!pte.is_unused());
assert!(pte.is_present());
assert_eq!(pte.paddr(), paddr);
assert_eq!(
    pte.bits(),
    0x800_0000000233_003, // PRESENT | WRITE | NO_EXECUTE | paddr(0x233000)
);

Dependencies

~725KB
~13K SLoC