在Armv8中,每个页表项(PTE)位数为64位,其中低12位是用来表示物理地址偏移量的。由于4K大小的页面是2的幂次方,因此低12位总是0,这意味着64位PTE可以表示2的52次方个4K页面。
Armv8中使用了48位虚拟地址和52位物理地址,这意味着VMMU地址范围是2的48次方页,即可以对2的40次方个4K页面进行虚拟内存映射。
以下是用C语言实现的地址范围计算示例代码:
#include
#include
#define VADDR_BITS 48
#define PADDR_BITS 52
#define PAGE_SIZE 4096
int main() {
uint64_t vmmu_limit = 1ul << VADDR_BITS;
uint64_t num_pages = 1ul << (PADDR_BITS - PAGE_SIZE);
uint64_t page_limit = num_pages * PAGE_SIZE;
printf("VMMU地址范围:0x%lx - 0x%lx\n", 0ul, vmmu_limit - 1);
printf("物理地址范围:0x%lx - 0x%lx\n", 0ul, page_limit - 1);
return 0;
}