mirror of
https://github.com/geode-sdk/geode.git
synced 2024-12-14 18:11:15 -05:00
85 lines
2.2 KiB
C++
85 lines
2.2 KiB
C++
|
#include "PlatformUtil/ProcessRuntimeUtility.h"
|
||
|
|
||
|
#include <vector>
|
||
|
|
||
|
#include <windows.h>
|
||
|
|
||
|
#define LINE_MAX 2048
|
||
|
|
||
|
// ================================================================
|
||
|
// GetProcessMemoryLayout
|
||
|
|
||
|
static bool memory_region_comparator(MemoryRegion a, MemoryRegion b) {
|
||
|
return (a.address > b.address);
|
||
|
}
|
||
|
|
||
|
|
||
|
// https://gist.github.com/jedwardsol/9d4fe1fd806043a5767affbd200088ca
|
||
|
|
||
|
|
||
|
std::vector<MemoryRegion> ProcessMemoryLayout;
|
||
|
std::vector<MemoryRegion> ProcessRuntimeUtility::GetProcessMemoryLayout() {
|
||
|
if (!ProcessMemoryLayout.empty()) {
|
||
|
ProcessMemoryLayout.clear();
|
||
|
}
|
||
|
|
||
|
char *address{nullptr};
|
||
|
MEMORY_BASIC_INFORMATION region;
|
||
|
|
||
|
while(VirtualQuery(address,®ion,sizeof(region)))
|
||
|
{
|
||
|
address += region.RegionSize;
|
||
|
if (!(region.State & (MEM_COMMIT | MEM_RESERVE))) {
|
||
|
continue;
|
||
|
}
|
||
|
|
||
|
MemoryPermission permission = MemoryPermission::kNoAccess;
|
||
|
auto mask = PAGE_GUARD | PAGE_NOCACHE | PAGE_WRITECOMBINE;
|
||
|
switch(region.Protect & ~mask)
|
||
|
{
|
||
|
case PAGE_NOACCESS:
|
||
|
case PAGE_READONLY:
|
||
|
break;
|
||
|
|
||
|
case PAGE_EXECUTE:
|
||
|
case PAGE_EXECUTE_READ:
|
||
|
permission = MemoryPermission::kReadExecute;
|
||
|
break;
|
||
|
|
||
|
case PAGE_READWRITE:
|
||
|
case PAGE_WRITECOPY:
|
||
|
permission = MemoryPermission::kReadWrite;
|
||
|
break;
|
||
|
|
||
|
case PAGE_EXECUTE_READWRITE:
|
||
|
case PAGE_EXECUTE_WRITECOPY:
|
||
|
permission = MemoryPermission::kReadWriteExecute;
|
||
|
break;
|
||
|
}
|
||
|
|
||
|
ProcessMemoryLayout.push_back(MemoryRegion{(void *)region.BaseAddress, region.RegionSize, permission});
|
||
|
}
|
||
|
return ProcessMemoryLayout;
|
||
|
}
|
||
|
|
||
|
// ================================================================
|
||
|
// GetProcessModuleMap
|
||
|
|
||
|
std::vector<RuntimeModule> ProcessModuleMap;
|
||
|
|
||
|
std::vector<RuntimeModule> ProcessRuntimeUtility::GetProcessModuleMap() {
|
||
|
if (!ProcessMemoryLayout.empty()) {
|
||
|
ProcessMemoryLayout.clear();
|
||
|
}
|
||
|
return ProcessModuleMap;
|
||
|
}
|
||
|
|
||
|
RuntimeModule ProcessRuntimeUtility::GetProcessModule(const char *name) {
|
||
|
std::vector<RuntimeModule> ProcessModuleMap = GetProcessModuleMap();
|
||
|
for (auto module : ProcessModuleMap) {
|
||
|
if (strstr(module.path, name) != 0) {
|
||
|
return module;
|
||
|
}
|
||
|
}
|
||
|
return RuntimeModule{0};
|
||
|
}
|