- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我已经编写了一个共享对象来修改 FreeType 的 FT_Load_Glyph
和 FT_Render_Glyph
函数的参数,目前通过将其插入 LD_PRELOAD
和 dlsym
。
这工作正常,但我很想知道是否有办法进行这些更改:
LD_PRELOAD
应用于主机上的所有程序;我能想出的唯一两个“解决方案”是丑陋的黑客:
LD_PRELOAD
所有程序,这看起来缓慢而脆弱;或libfreetype.so.6.12.3
到 libxxxxtype.so.6.12.3
;然后
libxxxxtype.so.6.12.3
中的soname修改为libxxxxtype.so.6
;libxxxxtype.so.6
;和libfreetype.so.6.999
.我基本上想透明地修补共享对象中的几个函数,同时让其余函数通过,而不必访问共享对象的源代码或使用它的程序,但是如果我做一个带有 soname libfreetype.so.6
的假共享对象,我看不到将它链接到(或 dlopen
)真正的 libfreetype.so 的干净方法.6
。
这是我第一次使用共享库进行真正的实验,所以如果这个问题做出了一些不正确的假设,或者根本没有意义,请多多包涵。
最佳答案
你能尝试使用 uprobes
来动态窃取某些函数的控制权吗?
检查 http://www.brendangregg.com/blog/2015-06-28/linux-ftrace-uprobe.html
uprobes: user-level dynamic tracing, which was added to Linux 3.5 and improved in Linux 3.14. It lets you trace user-level functions; for example, the return of the readline() function from all running bash shells, with the returned string:
# ./uprobe 'r:bash:readline +0($retval):string'
Tracing uprobe readline (r:readline /bin/bash:0x8db60 +0($retval):string). Ctrl-C to end.
bash-11886 [003] d... 19601837.001935: readline: (0x41e876 <- 0x48db60) arg1="ls -l"
bash-11886 [002] d... 19601851.008409: readline: (0x41e876 <- 0x48db60) arg1="echo "hello world""
bash-11886 [002] d... 19601854.099730: readline: (0x41e876 <- 0x48db60) arg1="df -h"
bash-11886 [002] d... 19601858.805740: readline: (0x41e876 <- 0x48db60) arg1="cd .."
bash-11886 [003] d... 19601898.378753: readline: (0x41e876 <- 0x48db60) arg1="foo bar"
^C
Ending tracing...
和http://www.brendangregg.com/blog/2015-07-03/hacking-linux-usdt-ftrace.html
还有其他跟踪用户空间函数的解决方案,如 ftrace、systemtap、dtrace、lttng。其中一些需要重新编译并在程序中静态定义跟踪点;和 uprobes 是“用户级动态跟踪”。
关于 uprobes 的一些链接:
uprobes 的handler
有pt_regs
。如上一个链接所述:“Uprobes 因此实现了一种机制,每当进程执行特定指令位置时都可以调用内核函数。”它表明 uprobes 可能会取代一些基于 ptrace/gdb 的解决方案;因此有可能通过更改其 eip/rip (PC) 寄存器来更改任何程序命中事件 uprobe 的执行。
您可以尝试一些其他的动态检测工具,例如pin
或dyninst
;但它们是为每个进程使用而设计的。
关于linux - 通过 soname 插入共享对象的一部分,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37148908/
如何以一种方式链接二进制文件以与两个现有版本的库兼容,这两个版本具有冲突的 SONAME ?这两个版本不共享相同的 SONAME 前缀。一个是 libcapi10.so.3,另一个是 libcapi1
我正在尝试在 64 位 Ubuntu 12.04 上构建 SLitrani。我已经从源代码构建了 ROOT 5.34.03,我确实弄清楚了如何为 $ROOTDEV 设置 LD_LIBRARY_PATH
如果我创建一个没有像这样的 SONAME 的共享库 gcc -shared libfoo.o -o libfoo.so 并链接到它, 链接器如何找到我的共享库? 是文件名libfoo.so被链接器视为
我正在编译 sipXtapi,我需要用这一行编译 gcc -shared -DPIC .libs/codec_pcmapcmu_la-CodecPcmaWrapper.o .libs/codec_
我制作了一个程序,它使用两个共享库(我编译的)并且放置如下: /home_directory_where_I_compile_and_run_everything -->/lib/libjson_li
我已经编写了一个共享对象来修改 FreeType 的 FT_Load_Glyph 和 FT_Render_Glyph 函数的参数,目前通过将其插入 LD_PRELOAD 和 dlsym。 这工作正常,
我学会了“ Program Library HOWTO ”。它提到使用 soname 来管理版本,如下所示。 gcc -shared -fPIC -Wl,-soname,libfoo.so.1 -o
我正在为一个库制作一个 Debian 包,我称之为 libmystuff。目前版本为 4.0.0,下一个版本将是 4.1.0,并且可能会破坏 API 兼容性。该项目使用 CMake 构建。 这在 so
我正在使用 eclipse cdt 来编译和运行 C++ 应用程序。 My_main_program 特别需要 libjpeg.so.62。 我的 Ubuntu 系统以前在 /usr/local/li
我正在使用 Cmake for Android(使用 Android NDK)编译 libclang。 这是配置文件名和soname的CMake配置部分: set_target_properties(
我想从不同平台上的源代码构建Boost。我已经能够在linux上(在docker镜像上)做到这一点。我也可以在自己的计算机(Mac OS X 10.13 Xcode 9.4.1)上执行此操作,但是当我
我正在尝试在 mysql 5.5 中安装半同步复制并尝试执行以下命令: 安装插件“rpl_semi_sync_master”SONAME“semisync_master.so” 但是这个命令抛出以下错
我正在尝试使用 cmake 构建一个 rpm 包。这个包构建了一个库并将其打包好,一切都是 hunky-dory 在下一次迭代中,我使用以下命令添加“soname” set_property(TARG
据我了解,“/lib/ld-linux.so.2”中的“2”很少更改。有不能与新库一起工作的旧程序,也有不能与旧库一起工作的新程序。但它们都引用/lib/ld-linux.so.2,从而阻止安装这两个
我尝试在 Mac OS X 上使用 CMake 构建我的应用程序,但出现以下错误: Linking CXX shared library libsml.so ld: unknown option: -
我正在用 cmake android 交叉编译 gdcm,直到编译结束,但最后我得到以下错误。你们如何在编译库时在 cmake-gui 或 cmake 中设置 -soname,这样我们就可以避免以下类
我是一名优秀的程序员,十分优秀!