2014-06-25 00:38:34 +02:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
|
|
#define SYS_MMAPPER_FIXED_ADDR 0xB0000000
|
|
|
|
|
#define SYS_MMAPPER_FIXED_SIZE 0x10000000
|
|
|
|
|
|
|
|
|
|
struct mmapper_info
|
|
|
|
|
{
|
|
|
|
|
u32 size;
|
2014-08-30 22:41:01 +02:00
|
|
|
u64 flags;
|
2014-06-25 00:38:34 +02:00
|
|
|
|
2014-09-02 23:48:44 +02:00
|
|
|
mmapper_info(u32 _size, u64 _flags)
|
|
|
|
|
: size(_size)
|
2014-06-25 00:38:34 +02:00
|
|
|
, flags(_flags)
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
mmapper_info()
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
2015-05-27 05:11:59 +02:00
|
|
|
REG_ID_TYPE(mmapper_info, 0x08); // SYS_MEM_OBJECT
|
|
|
|
|
|
2014-06-25 00:38:34 +02:00
|
|
|
// SysCalls
|
|
|
|
|
s32 sys_mmapper_allocate_address(u32 size, u64 flags, u32 alignment, u32 alloc_addr);
|
|
|
|
|
s32 sys_mmapper_allocate_fixed_address();
|
2014-10-11 19:20:01 +02:00
|
|
|
s32 sys_mmapper_allocate_memory(u32 size, u64 flags, vm::ptr<u32> mem_id);
|
|
|
|
|
s32 sys_mmapper_allocate_memory_from_container(u32 size, u32 cid, u64 flags, vm::ptr<u32> mem_id);
|
2014-06-25 00:38:34 +02:00
|
|
|
s32 sys_mmapper_change_address_access_right(u32 start_addr, u64 flags);
|
|
|
|
|
s32 sys_mmapper_free_address(u32 start_addr);
|
|
|
|
|
s32 sys_mmapper_free_memory(u32 mem_id);
|
|
|
|
|
s32 sys_mmapper_map_memory(u32 start_addr, u32 mem_id, u64 flags);
|
|
|
|
|
s32 sys_mmapper_search_and_map(u32 start_addr, u32 mem_id, u64 flags, u32 alloc_addr);
|
|
|
|
|
s32 sys_mmapper_unmap_memory(u32 start_addr, u32 mem_id_addr);
|
|
|
|
|
s32 sys_mmapper_enable_page_fault_notification(u32 start_addr, u32 q_id);
|