- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想拦截 dlopen() 内部发生的所有文件系统访问。起初,它看起来像 LD_PRELOAD
或 -Wl,-wrap,
将是可行的解决方案,但由于某些技术原因,我无法使其正常工作:
_dl_*
工作函数此时已解决,因此将来的调用会通过它们。我认为 LD_PRELOAD
太晚了。 malloc
规避了上述问题,因为 malloc()
ld.so 内部没有功能 free()
, 它只是调用 memset()
. __libc_read()
, 包含在 ld.so
是静态的,所以我无法用 -Wl,-wrap,__libc_read
拦截它们. ld.so
直接从源代码而不是将其链接到包装器中。那里的挑战是
libc
和
rtld-libc
是从相同的来源构建的。我知道宏
IS_IN_rtld
在构建
rtld-libc
时定义,但是如何保证只有一个静态数据结构的副本,同时仍然导出一个公共(public)接口(interface)函数呢? (这是一个 glibc 构建系统问题,但我还没有找到这些细节的文档。)
dlopen()
?
FUSE
这样的 Linux 特定解决方案。因为这是针对不支持此类事物的最小“计算节点”内核。
最佳答案
it would seem like LD_PRELOAD or -Wl,-wrap, would be viable solutions
--wrap
解决方案不可能可行:它仅在(静态)链接时有效,并且您的
ld.so
和
libc.so.6
和
libdl.so.2
都已经链接,所以现在使用
--wrap
为时已晚。
LD_PRELOAD
本来可以工作,除了 ... ld.so 认为
dlopen()
调用
open()
是一个内部实现细节。因此,它只是调用内部
__open
函数,绕过
PLT
,以及您插入
open
的能力。
Somehow malloc circumvents the issue
libc
支持实现自己的
malloc
的用户(例如用于调试目的)。所以调用例如来自
calloc
的
dlopen
确实经过
PLT
,并且可以通过
LD_PRELOAD
插入。
This might all mean that I need to build my own ld.so directly from source instead of linking it into a wrapper.
ld.so
会做什么?我认为您希望它调用
__libc_open
(在
libc.so.6
中),但是由于显而易见的原因,这不可能起作用:首先是
ld.so
open
s
libc.so.6
(在进程启动时)。
ld.so
的调用替换为对
__open
的调用来重建
open
。这将导致
ld.so
穿过
PLT
,并将其暴露给
LD_PRELOAD
插入。
ld.so
(出错并导致系统无法启动的可能性太大了)。相反,将其安装到例如
/usr/local/my-ld.so
,然后将您的二进制文件与
-Wl,--dynamic-linker=/usr/local/my-ld.so
链接。
.text
的
ld.so
,然后查找
CALL __open
指令。如果
ld.so
没有被剥离,那么您可以找到内部
__open
和您要修补的功能(例如
open_verify
中的
dl-load.c
)。一旦你找到有趣的
CALL
,
mprotect
包含它的页面是可写的,并修补你自己的插入器的地址(如果需要,它可以反过来调用
__libc_open
),然后
mprotect
它回来。任何 future 的
dlopen()
现在都将通过您的插入器。
关于glibc - 如何在 dlopen() 中拦截文件系统访问?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7699583/
这个问题在这里已经有了答案: Multiple glibc libraries on a single host (11 个回答) 5年前关闭。 有没有办法在本地文件夹中安装新版本的 GLIBC?我将
这个问题在这里已经有了答案: Deploying Yesod to Heroku, can't build statically (4 个回答) 1年前关闭。 我有两台机器 RHEL 4机 RHEL
我在 C 启动时读取 article ,它指的是函数 __libc_csu_init 。谁能告诉我CSU代表什么? 最佳答案 我在 libc p 中找到了对“ C s tart u p”的引用。 这远
我正在使用 AlpineLinux(安装在我的计算机上,而不是安装在 docker 中)并且我正在尝试使用依赖于 glibc 的共享库。 由于 Glibc 没有集成到这个发行版中,我看到开发了一个替代
所以我正在玩 Alpine Linux,它使用 musl 与 glibc。 我发现由于这个选择,我无法运行 Oracle Java 或在 glibc 下构建的静态二进制文件。 musl 是否应该与更广
在构建 glibc 时,出现此错误。 *glibc/build/elf/dl-allobjs.os: file not recognized: File format not recognized c
我一直在寻找没有好的结果。 我想知道在文本中解释为 Malloc Maleficarum 或 Malloc Des-Malleficarum 的技术在 glibc 2.12.1 版本中是否有效。 在提
我在 CentOS 上安装 gcc 时遇到问题。 我的命令的输出sudo yum install gcc: Loaded plugins: fastestmirror Loading mirror s
我想下载gzip类型的mariadb,但是我发现它有很多文件可以下载,例如mariadb-10.2.6-linux-x86_64.tar.gz,mariadb-10.2.6-linux-glibc_2
我想尝试使用不同的 glibc 的 sin 函数。他们是否可以在不编译整个 glibc 的情况下使用不同 glibc 版本的 sin 函数? 我已经在我的虚拟 ubuntu 机器上下载了不同版本的 g
我要在超算中心的目录下安装一个软件,但是sudo,root,连apt-get,yum都不能用...这个软件需要glibc2.7,所以我得手动安装gcc和glibc(因为我无法更改内置 gcc 的路径来
我正在研究需要在多个不同的嵌入式平台上运行的 C 和 C++ 程序,为此我有交叉编译器,因此我可以在我的 x86 桌面上进行构建。 我在某些功能上遇到了一个可怕的问题,例如“strtod()”。这是我
我遇到了一个非常烦人的问题:我有一个程序,它在开始时创建一个线程,该线程将在执行期间启动其他内容(fork() 紧随其后的是 execve())。 这是我的程序达到(我认为)死锁时两个线程的 bt:
我刚刚发现,glibc 2.23 有一个关于 stdio 函数 fmemopen() 的错误,参见例如Using rewind() on a FILE* opened with fmemopen .
[root@localhost Keystone2]# sudo rpm -ivh glibc-2.3.4-2.9.audit.x86_64.rpm --nodeps --force warning:
从该系列中很容易找到如何使用 dlsym()和其他函数,但是在内部如何工作呢?是否可以编写自己的,容易实现的dlsym()? 我想知道是否有可能实现类似的行为,但在不将与-ldl链接的情况下实现(可以
嗨,我目前使用的是 ubuntu 9.10 和 glibc 版本 2.11.1-0,好吧,我正在做一个项目,我想用 glibc 的另一个版本(2.5-58)进行测试,我想知道以下与此相关的事情: 如何
我已经下载了glibc,这样我就可以修改它的代码然后使用它。所以只是为了玩玩它,我更改了 glibc 的 stdio-common 目录中的 printf 函数,以便它打印“你可以看到我吗?”。 in
我正在集群上的 conda 环境中部署 R 脚本。该脚本加载了一些需要 glibc 版本 >= 2.14 的包。虽然我的系统的 glibc 版本为 2.14,但集群的 glibc 版本为 2.12,我
所以。我有一个问题,我在一台机器上有两个版本的 GCC。 3.4.6 和 4.1 这是由于新软件的一些依赖性问题。 (需要 glibc 4.1) 当我将这个新软件与 4.1 库链接时,它链接得很好。但
我是一名优秀的程序员,十分优秀!