## Page Table Implementations

- Issues in implementing the page table
- Multi-level page table
- Inverted page table
- Hashed page table

## Implementation of Page Table



Observation: Page table must store one entry per page.

Question: How to store the page table?

Naïve solution: Store page table as array in memory.

- Page-Table-Base-Register (PTBR) points to start of array.
- New PTBR loaded during address space switch.



Problem: Page table can become very large.

Example: 32-bit address space (4GB), 4kB pages, 4B entries

- => 2<sup>20</sup> entries in page table
- => we need 4MB per process (!)













## Summary

- Page table size is an issue for large address spaces.
- Multi-level page table
- Inverted page table
- Hashed page table