2020-07-25 16:54:37 -05:00
|
|
|
/**
|
|
|
|
* \file
|
|
|
|
*/
|
|
|
|
|
2019-02-09 12:52:45 -06:00
|
|
|
#ifndef PAGING_H
|
|
|
|
#define PAGING_H
|
|
|
|
|
2020-07-25 16:54:37 -05:00
|
|
|
/**
|
|
|
|
* Map virtual pages to physical frames.
|
|
|
|
* \param virt_addr_ptr The start of the virtual range to map.
|
|
|
|
* \param phys_addr_ptr The start of the physical range to map.
|
|
|
|
* \param num_pages The number of pages to map.
|
|
|
|
* \param usr Are the pages acessible by user mode code
|
|
|
|
* \param wr Are the pages writable by user mode code (kernel always has write permissions)
|
|
|
|
*/
|
2019-03-11 09:32:55 -05:00
|
|
|
void map_pages(void* virt_addr_ptr,void* phys_addr_ptr,int num_pages,char usr,char wr);
|
2020-07-25 16:54:37 -05:00
|
|
|
/**
|
|
|
|
* Unmap virtual pages,
|
|
|
|
* \param start_virt The start of the virtual range to unmap.
|
|
|
|
* \param num_pages The number of pages to map.
|
|
|
|
*/
|
2020-07-23 11:50:23 -05:00
|
|
|
void unmap_pages(void* start_virt,int num_pages);
|
2020-07-25 16:54:37 -05:00
|
|
|
/**
|
|
|
|
* Allocate virtual pages & map them to physical memory.
|
|
|
|
* \param num_pages The number of pages to allocate.
|
|
|
|
* \return a pointer to the allocated pages.
|
|
|
|
*/
|
2019-03-11 09:32:55 -05:00
|
|
|
void* alloc_pages(int num_pages);
|
2020-07-25 16:54:37 -05:00
|
|
|
/**
|
|
|
|
* Allocate virtual pages at a specific address & map them to physical memory.
|
|
|
|
* \param num_pages The number of pages to allocate.
|
|
|
|
* \param addr The adress to start allocation at.
|
|
|
|
*/
|
2019-03-11 09:32:55 -05:00
|
|
|
void alloc_pages_virt(int num_pages,void* addr);
|
2020-07-25 16:54:37 -05:00
|
|
|
/**
|
|
|
|
* Initialize paging
|
|
|
|
*/
|
2019-02-09 13:05:13 -06:00
|
|
|
void paging_init();
|
2020-07-25 16:54:37 -05:00
|
|
|
/**
|
|
|
|
* Create a new address space
|
|
|
|
* \return a pointer to the new address space in physical memory.
|
|
|
|
*/
|
2019-05-05 13:14:14 -05:00
|
|
|
void* paging_new_address_space();
|
2020-07-25 16:54:37 -05:00
|
|
|
/**
|
|
|
|
* Load an address space
|
|
|
|
* \param cr3 The address space to load
|
|
|
|
*/
|
2020-07-22 19:26:55 -05:00
|
|
|
void load_address_space(void* cr3);
|
2020-07-25 16:54:37 -05:00
|
|
|
/**
|
|
|
|
* Convert a virtual address to a physical one.
|
|
|
|
* \param virt_addr The virtual address to convert
|
|
|
|
* \return the physical adress it maps to, or NULL if it is not mapped.
|
|
|
|
*/
|
2019-05-04 10:42:17 -05:00
|
|
|
void* virt_to_phys(void* virt_addr);
|
2020-07-25 16:54:37 -05:00
|
|
|
/**
|
|
|
|
* Finds free virtual pages and returns the start address
|
|
|
|
* \param num_pages The minimum size of the free area
|
|
|
|
* \return the start of the free area
|
|
|
|
*/
|
2019-09-22 08:25:08 -05:00
|
|
|
void* find_free_pages(int num_pages);
|
2020-07-25 16:54:37 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the current address space
|
|
|
|
* \return a pointer to the current address space in physical memory.
|
|
|
|
*/
|
2020-07-22 19:26:55 -05:00
|
|
|
void* get_cr3();
|
2019-05-04 10:52:38 -05:00
|
|
|
|
2019-02-09 12:52:45 -06:00
|
|
|
#endif
|