相关疑难解决方法(0)

将静态链接的elf二进制文件转换为动态链接

我有一个静态链接到libc的精灵二进制文件.我无法访问其C代码.我想使用OpenOnload库,它在用户空间中实现了套接字,因此与标准libc版本相比可以提供更低的延迟.OpenOnload实现标准套接字api,并使用LD_PRELOAD覆盖libc版本.但是,由于此elf二进制文件是静态链接的,因此无法使用套接字API的OpenOnload版本.

我相信可以通过以下步骤将此二进制文件转换为与OpenOnload动态链接:

  1. 添加新的程序头:PT_INTERP,PT_DYNAMIC和PT_LOAD.
  2. 在PT_DYNAMIC中添加条目以列出与libc的依赖关系.
  3. 在新的PT_LOAD部分中为所需的libc函数添加PLT存根.
  4. 修改libc函数的现有二进制代码以跳转到相应的PLT存根.

作为第一个剪辑,我尝试添加3个PT_LOAD段.在现有PT_LOAD段标头之后添加了新的段标头.此外,未修改现有段的vm_addr.基于p_align将现有段的文件偏移量下移到下一个对齐的地址.在文件末尾的文件中添加了新的PT_LOAD段.

在重新编写文件之后,当我运行它时,它被内核正确加载,但随后它立即发生了故障.

我的问题是:

  1. 如果我只是在elf二进制文件中移动文件偏移量而不修改vm_addresses,那么运行二进制文件时是否会导致任何错误?
  2. 我可以做我正在尝试的事情吗?有人试过吗?

c linux elf openonload

9
推荐指数
1
解决办法
1803
查看次数

标签 统计

c ×1

elf ×1

linux ×1

openonload ×1