2022-11-13 13:29:15 +00:00
|
|
|
#pragma once
|
2022-12-04 11:42:43 +00:00
|
|
|
#include <luna/Result.h>
|
2023-03-29 15:28:22 +00:00
|
|
|
#include <luna/String.h>
|
2022-12-04 11:42:43 +00:00
|
|
|
#include <luna/Types.h>
|
2022-11-13 13:29:15 +00:00
|
|
|
|
|
|
|
namespace MemoryManager
|
|
|
|
{
|
|
|
|
void init();
|
|
|
|
|
2022-11-16 19:02:04 +00:00
|
|
|
Result<void> protect_kernel_sections();
|
|
|
|
|
2022-11-19 21:27:08 +00:00
|
|
|
Result<u64> alloc_frame();
|
|
|
|
Result<void> free_frame(u64 frame);
|
2023-03-16 22:02:53 +00:00
|
|
|
Result<void> free_frames(u64 address, usize count);
|
2022-11-13 13:29:15 +00:00
|
|
|
|
2022-11-19 21:27:08 +00:00
|
|
|
void lock_frame(u64 frame);
|
2022-12-07 09:55:47 +00:00
|
|
|
void lock_frames(u64 frames, usize count);
|
2022-11-13 15:56:03 +00:00
|
|
|
|
2022-11-16 19:30:34 +00:00
|
|
|
Result<void> remap(u64 address, usize count, int flags);
|
|
|
|
Result<void> remap_unaligned(u64 address, usize count, int flags);
|
2022-11-16 19:02:04 +00:00
|
|
|
|
2022-11-19 17:38:47 +00:00
|
|
|
bool validate_readable_page(u64 address);
|
|
|
|
bool validate_writable_page(u64 address);
|
|
|
|
|
2023-01-07 00:39:33 +00:00
|
|
|
bool validate_user_readable_page(u64 address);
|
|
|
|
bool validate_user_writable_page(u64 address);
|
|
|
|
|
2023-01-05 21:39:09 +00:00
|
|
|
bool validate_userspace_string(u64 address);
|
2023-03-29 15:28:22 +00:00
|
|
|
Result<String> strdup_from_user(u64 address);
|
2023-01-05 21:39:09 +00:00
|
|
|
|
2023-01-07 00:39:33 +00:00
|
|
|
bool validate_user_write(void* user, usize size);
|
|
|
|
bool validate_user_read(const void* user, usize size);
|
|
|
|
|
|
|
|
template <typename T> bool validate_user_write_typed(T* user)
|
|
|
|
{
|
|
|
|
return validate_user_write(user, sizeof(T));
|
|
|
|
}
|
|
|
|
|
|
|
|
template <typename T> bool validate_user_read_typed(const T* user)
|
|
|
|
{
|
|
|
|
return validate_user_read(user, sizeof(T));
|
|
|
|
}
|
|
|
|
|
2023-01-06 23:17:16 +00:00
|
|
|
bool copy_to_user(void* user, const void* kernel, usize size);
|
|
|
|
|
|
|
|
template <typename T> bool copy_to_user_typed(T* user, const T* kernel)
|
|
|
|
{
|
|
|
|
return copy_to_user(user, kernel, sizeof(T));
|
|
|
|
}
|
|
|
|
|
2023-01-11 18:25:28 +00:00
|
|
|
bool copy_from_user(const void* user, void* kernel, usize size);
|
|
|
|
|
|
|
|
template <typename T> bool copy_from_user_typed(const T* user, T* kernel)
|
|
|
|
{
|
|
|
|
return copy_from_user(user, kernel, sizeof(T));
|
|
|
|
}
|
|
|
|
|
2022-11-19 21:32:48 +00:00
|
|
|
Result<void> map_frames_at(u64 virt, u64 phys, usize count, int flags);
|
2023-02-27 11:47:17 +00:00
|
|
|
Result<void> map_huge_frames_at(u64 virt, u64 phys, usize count, int flags);
|
2022-11-19 21:28:45 +00:00
|
|
|
|
|
|
|
Result<u64> alloc_at(u64 virt, usize count, int flags);
|
2022-12-16 18:36:38 +00:00
|
|
|
Result<u64> alloc_for_kernel(usize count, int flags);
|
2022-11-19 21:28:45 +00:00
|
|
|
|
2022-12-23 10:30:49 +00:00
|
|
|
Result<u64> get_kernel_mapping_for_frames(u64 phys, usize count, int flags);
|
|
|
|
|
2022-11-19 21:28:45 +00:00
|
|
|
Result<void> unmap_owned(u64 virt, usize count);
|
2022-12-16 18:36:38 +00:00
|
|
|
Result<void> unmap_owned_and_free_vm(u64 virt, usize count);
|
2022-11-19 21:28:45 +00:00
|
|
|
Result<void> unmap_weak(u64 virt, usize count);
|
2023-01-05 20:50:06 +00:00
|
|
|
Result<void> unmap_weak_and_free_vm(u64 virt, usize count);
|
2022-11-19 21:28:45 +00:00
|
|
|
|
2023-02-27 11:47:17 +00:00
|
|
|
Result<void> unmap_weak_huge(u64 virt, usize count);
|
|
|
|
|
2022-12-07 09:55:47 +00:00
|
|
|
usize free();
|
|
|
|
usize used();
|
|
|
|
usize reserved();
|
|
|
|
usize total();
|
2023-01-02 12:07:29 +00:00
|
|
|
}
|