2022-09-06 16:08:15 +00:00
|
|
|
#pragma once
|
|
|
|
#include <stdint.h>
|
|
|
|
|
2022-10-08 12:52:28 +00:00
|
|
|
#ifndef PAGE_SIZE
|
|
|
|
#define PAGE_SIZE 4096
|
|
|
|
#endif
|
|
|
|
|
2022-09-22 05:57:30 +00:00
|
|
|
#define MAP_READ_WRITE 1 << 0
|
|
|
|
#define MAP_USER 1 << 1
|
2022-09-23 14:41:43 +00:00
|
|
|
#define MAP_EXEC 1 << 2
|
Kernel: Introduce page ownership
Some pages, such as framebuffer pages, are not physical memory frames reserved for the current process.
Some, such as the framebuffer, may be shared between all processes.
Yet, on exit() or on exec(), a process frees all frames mapped into its address spaces.
And on fork(), it copies all data between frames. So how could we map framebuffers.
Simple: we use one of the bits in page table entries which are available to the OS, and mark whether that page is owned by the current process.
If it is owned, it will be:
- Freed on address space destruction
- Its data will be copied to a new page owned by the child process on fork()
If it is not owned, it will be:
- Left alone on address space destruction
- On fork(), the child's virtual page will be mapped to the same physical frame as the parent
This still needs a bit more work, such as keeping a reference of how many processes use a page to free it when all processes using it exit/exec.
This should be done for MAP_SHARED mappings, for example, since they are not permanent forever,
unlike the framebuffer for example.
2022-11-02 18:32:28 +00:00
|
|
|
#define MAP_AS_OWNED_BY_TASK 1 << 3
|
2022-09-22 05:57:30 +00:00
|
|
|
|
2022-09-24 19:45:13 +00:00
|
|
|
namespace MemoryManager
|
2022-09-06 16:08:15 +00:00
|
|
|
{
|
2022-09-25 15:38:17 +00:00
|
|
|
void init();
|
|
|
|
|
2022-11-02 17:34:57 +00:00
|
|
|
void protect_kernel_sections();
|
|
|
|
|
2022-09-22 05:57:30 +00:00
|
|
|
void* get_mapping(void* physicalAddress, int flags = MAP_READ_WRITE);
|
2022-09-06 16:08:15 +00:00
|
|
|
void release_mapping(void* mapping);
|
|
|
|
|
2022-09-22 05:57:30 +00:00
|
|
|
void* get_unaligned_mapping(void* physicalAddress, int flags = MAP_READ_WRITE);
|
|
|
|
void* get_unaligned_mappings(void* physicalAddress, uint64_t count, int flags = MAP_READ_WRITE);
|
2022-09-07 08:33:22 +00:00
|
|
|
void release_unaligned_mapping(void* mapping);
|
2022-09-07 17:41:08 +00:00
|
|
|
void release_unaligned_mappings(void* mapping, uint64_t count);
|
2022-09-07 08:33:22 +00:00
|
|
|
|
2022-09-22 05:57:30 +00:00
|
|
|
void* get_page(int flags = MAP_READ_WRITE);
|
|
|
|
void* get_pages(uint64_t count, int flags = MAP_READ_WRITE);
|
2022-09-06 16:08:15 +00:00
|
|
|
|
2022-10-01 10:12:50 +00:00
|
|
|
void* get_page_at(uint64_t addr, int flags = MAP_READ_WRITE);
|
|
|
|
void* get_pages_at(uint64_t addr, uint64_t count, int flags = MAP_READ_WRITE);
|
|
|
|
|
2022-09-06 16:08:15 +00:00
|
|
|
void release_page(void* page);
|
|
|
|
void release_pages(void* pages, uint64_t count);
|
2022-10-13 19:14:39 +00:00
|
|
|
|
|
|
|
void protect(void* page, uint64_t count, int flags);
|
2022-11-02 19:24:07 +00:00
|
|
|
|
2022-11-08 18:07:43 +00:00
|
|
|
void map_several_pages(uint64_t physicalAddress, uint64_t virtualAddress, uint64_t count,
|
|
|
|
int flags = MAP_READ_WRITE);
|
2022-09-06 16:08:15 +00:00
|
|
|
}
|