mirror of https://git.suyu.dev/suyu/suyu
vm_manager: Amend the returned values for invalid memory queries in QueryMemory()
The kernel returns a memory info instance with the base address set to the end of the address space, and the size of said block as 0 - address_space_end, it doesn't set both of said members to zero.
This commit is contained in:
parent
a8cc03502b
commit
eb5f3f67f6
|
@ -28,7 +28,7 @@ static const char* GetMemoryStateName(MemoryState state) {
|
||||||
"IpcBuffer0", "Stack",
|
"IpcBuffer0", "Stack",
|
||||||
"ThreadLocal", "TransferMemoryIsolated",
|
"ThreadLocal", "TransferMemoryIsolated",
|
||||||
"TransferMemory", "ProcessMemory",
|
"TransferMemory", "ProcessMemory",
|
||||||
"Unknown2", "IpcBuffer1",
|
"Inaccessible", "IpcBuffer1",
|
||||||
"IpcBuffer3", "KernelStack",
|
"IpcBuffer3", "KernelStack",
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -312,10 +312,10 @@ MemoryInfo VMManager::QueryMemory(VAddr address) const {
|
||||||
memory_info.size = vma->second.size;
|
memory_info.size = vma->second.size;
|
||||||
memory_info.state = ToSvcMemoryState(vma->second.meminfo_state);
|
memory_info.state = ToSvcMemoryState(vma->second.meminfo_state);
|
||||||
} else {
|
} else {
|
||||||
memory_info.base_address = 0;
|
memory_info.base_address = address_space_end;
|
||||||
memory_info.permission = static_cast<u32>(VMAPermission::None);
|
memory_info.permission = static_cast<u32>(VMAPermission::None);
|
||||||
memory_info.size = 0;
|
memory_info.size = 0 - address_space_end;
|
||||||
memory_info.state = static_cast<u32>(MemoryState::Unmapped);
|
memory_info.state = static_cast<u32>(MemoryState::Inaccessible);
|
||||||
}
|
}
|
||||||
|
|
||||||
return memory_info;
|
return memory_info;
|
||||||
|
|
|
@ -105,6 +105,9 @@ enum class MemoryState : u32 {
|
||||||
|
|
||||||
ProcessMemory = 0x0F | FlagIPC3 | FlagIPC1 | FlagMapped | FlagMemoryPoolAllocated,
|
ProcessMemory = 0x0F | FlagIPC3 | FlagIPC1 | FlagMapped | FlagMemoryPoolAllocated,
|
||||||
|
|
||||||
|
// Used to signify an inaccessible or invalid memory region with memory queries
|
||||||
|
Inaccessible = 0x10,
|
||||||
|
|
||||||
IpcBuffer1 = 0x11 | FlagIPC3 | FlagIPC1 | FlagMapped | FlagQueryPhysicalAddressAllowed |
|
IpcBuffer1 = 0x11 | FlagIPC3 | FlagIPC1 | FlagMapped | FlagQueryPhysicalAddressAllowed |
|
||||||
FlagSharedDevice | FlagSharedDeviceAligned | FlagMemoryPoolAllocated,
|
FlagSharedDevice | FlagSharedDeviceAligned | FlagMemoryPoolAllocated,
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue