2022-10-19 15:13:16 +00:00
|
|
|
#pragma once
|
2022-10-20 16:50:07 +00:00
|
|
|
|
|
|
|
#ifndef MODULE
|
|
|
|
#define MODULE "mem"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "log/Log.h"
|
2022-10-19 15:13:16 +00:00
|
|
|
#include "memory/MemoryManager.h"
|
|
|
|
#include "memory/VMM.h"
|
|
|
|
#include "misc/utils.h"
|
2022-11-04 21:46:48 +00:00
|
|
|
#include <stddef.h>
|
2022-10-19 15:13:16 +00:00
|
|
|
|
|
|
|
char* strdup_from_user(const char* user_string);
|
2022-11-04 21:46:48 +00:00
|
|
|
bool validate_user_readable_page(uintptr_t address);
|
|
|
|
bool validate_user_writable_page(uintptr_t address);
|
|
|
|
bool validate_user_read(uintptr_t address, size_t size);
|
|
|
|
bool validate_user_write(uintptr_t address, size_t size);
|
2022-10-19 15:13:16 +00:00
|
|
|
|
2022-11-05 10:54:55 +00:00
|
|
|
bool copy_from_user(const void* user_ptr, void* ptr, size_t size);
|
|
|
|
bool copy_to_user(void* user_ptr, const void* ptr, size_t size);
|
|
|
|
|
2022-10-20 16:50:07 +00:00
|
|
|
// FIXME: Map the physical addresses into kernel address space. Right now, something overwrites KernelHeap and crashes
|
|
|
|
// it, so that's not really possible. But it should be done in the future.
|
|
|
|
|
2022-10-19 15:13:16 +00:00
|
|
|
template <typename T, unsigned long S = sizeof(T), typename V> T* user_address_to_typed_pointer(V address)
|
|
|
|
{
|
|
|
|
uint64_t phys = VMM::get_physical((uint64_t)address);
|
2022-10-20 16:50:07 +00:00
|
|
|
if (phys == (uint64_t)-1)
|
|
|
|
{
|
|
|
|
kinfoln("warning: user pointer is not mapped in its address space");
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
// return (T*)MemoryManager::get_unaligned_mappings((void*)phys, Utilities::get_blocks_from_size(PAGE_SIZE, S),
|
|
|
|
// MAP_READ_WRITE);
|
|
|
|
return (T*)phys;
|
2022-10-19 15:13:16 +00:00
|
|
|
}
|
|
|
|
|
2022-10-20 16:50:07 +00:00
|
|
|
template <typename T, unsigned long S = sizeof(T)> void free_user_typed_pointer(T*)
|
2022-10-19 15:13:16 +00:00
|
|
|
{
|
2022-10-20 16:50:07 +00:00
|
|
|
// MemoryManager::release_unaligned_mappings(ptr, Utilities::get_blocks_from_size(PAGE_SIZE, S));
|
2022-10-19 15:13:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
template <typename T> T* obtain_user_ref(T* user_ptr)
|
|
|
|
{
|
|
|
|
return user_address_to_typed_pointer<T>(user_ptr);
|
|
|
|
}
|
|
|
|
|
|
|
|
template <typename T> void release_user_ref(T* ptr)
|
|
|
|
{
|
|
|
|
return free_user_typed_pointer(ptr);
|
|
|
|
}
|