共享库通过LD_PRELOAD加载,同一个库的构造函数调用dlopen("libc.so.6")
问题是dlopen耗时很长,调试显示以下dlopen调用__dlopen,后者调用calloc,未知函数??,,最后是__GI___pthread_mutex_lock。
如我所料,在dlopen之前提供无限的资源,但不能解决问题。
只有当在Linux上使用目标应用程序Firefox设置LD_PRELOAD时才会出现问题(如上所述)。任何其他应用程序都可以正常工作(dlopen不会阻塞)!
发布于 2018-03-26 02:11:39
何时阻止dlopen?
当它需要一个由于某种原因而不可用的锁时。
调试演示
你需要更多的调试。dlopen调用calloc,这需要一个malloc锁。这没什么特别的。
一定是某个其他线程持有这个malloc锁,并且正在等待您的LD_PRELOADed库完成它的初始化(因此产生了一个死锁)。您应该能够使用(gdb) thread apply all where找到另一个线程。
您尝试在LD_PRELOADed库中插入什么函数可能也很重要。
https://stackoverflow.com/questions/48978371
复制相似问题