mach_vm_region_recurse,在 osx 上映射内存和共享库

2023-12-30

我使用 vm_region_recurse_64 来映射给定进程的内存,vmmap 样式。

然而,尝试通过检查内存中每个库的 Mach-O 标头来获取应用程序加载的共享库的完整列表,但 vm_region_recurse 似乎与 vmmap 命令行工具在某些特定内存部分的具体开始和结束位置方面不一致。

在加载大多数操作系统共享库的 90000000-a0000000 系统子图中尤其如此。

现在我有点困惑了。我可以列出内存段,大致了解它们是什么类型,并使用 vm_read 从中读取。但列出它们并得到correct事实证明,特定地区的信息很困难。

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;
    }
}

vmmap 调用 mach_vm_region_recurse() 来列出内存区域。

为了查看 0x90000000..0xa0000000 处的 dyld 共享缓存等子映射的内容,您需要查找设置了 is_submap 的区域,然后使用相同的地址和更深的嵌套深度再次调用 mach_vm_region_recurse() 。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

mach_vm_region_recurse,在 osx 上映射内存和共享库 的相关文章

随机推荐