我正在使用 vm_region_recurse_64 来映射给定进程的内存,vmmap 样式。
尝试通过检查内存中每个库的 Mach-O 标头来获取应用程序加载的共享库的完整列表,但是,vm_region_recurse 似乎不同意 vmmap 命令行工具关于某些特定内存部分开始和结束的具体位置。
这在 90000000-a0000000 系统子图中尤其如此,其中加载了大多数 os 共享库。
现在我有点难过。我可以列出内存段,大致说明它们是什么类型,并使用 vm_read 从它们中读取。但事实证明,列出它们并获得正确和特定的区域信息是困难的。
vmmap 如何获取加载库的特定位置的列表?我的方法似乎无效。
编辑:这是我正在使用的基本代码。它返回一个与 vmmap 相似但不相同的内存映射。没有特定库的内存区域。
kern_return_t krc = KERN_SUCCESS;
vm_address_t address = 0;
vm_size_t size = 0;
uint32_t depth = 1;
while (1) {
struct vm_region_submap_info_64 info;
mach_msg_type_number_t count = VM_REGION_SUBMAP_INFO_COUNT_64;
krc = vm_region_recurse_64(port, &address, &size, &depth, (vm_region_info_64_t)&info, &count);
if (krc == KERN_INVALID_ADDRESS){
break;
}
if (info.is_submap){
depth++;
}
else {
//do stuff
printf ("Found region: %08x to %08x\n", (uint32_t)address, (uint32_t)address+size);
address += size;
}
}