so 动态加载库 Hotpatch
fmms 13年前
<div id="p_fullcontent" class="detail"> <p>Hotpatch 是一个允许正在运行的进程动态加载一个 so 库的 C 库,类似于 Win32 上的 CreateRemoteThread() API。</p> <p>和其他现有的动态加载方案相比,Hotpatch 的优点是在<strong>加载 so 库之后将会恢复原先进程的运行状态</strong>。</p> <p>开发者可以利用 Hotpatch 实现:</p> <ul> <li>加载 so 库到一个已经运行的进程中。</li> <li>调用该 so 库中的自定义函数。</li> <li>向该函数传递序列化的参数。</li> </ul> <p>它包含三部分: <code>hotpatch.h</code> 头文件,<code>libhotpatch.so</code> 库和命令行辅助程序 <code>hotpatcher</code>。</p> <p>目前的局限有:</p> <ul> <li>用户只能向拥有权限的进程注入 so 库(当然 root 用户可以向所有进程注入)。</li> <li>目前仅支持 64 位 Linux,32 位支持将在下一个版本中完成。</li> <li>在编译共享库时需要加上连接器参数 <code>-fPIC -nostartfiles</code>。</li> <li>对于一个正在运行进程仅能动态加载一次 so 库文件。</li> </ul> <pre class="brush:cpp; toolbar: true; auto-links: false;">Sample Program ============== #include <hotpatch.h> int main(int argc, char **argv) { pid_t pid = argc > 1 ? atoi(argv[1]) : 0; hotpatch_t *hp = hotpatch_create(pid, 1); if (hp) { unsigned char *data = (unsigned char *)"my custom serialized data"; size_t datalen = strlen((char *)data) + 1; uintptr_t result1, result2; hotpatch_inject_library(hp, "libhotpatchtest.so", "mysym", data, datalen, &result1, &result2); hotpatch_destroy(hp); } return 0; }</pre>项目地址: <a href="/misc/goto?guid=4958192878176128296" target="_blank">https://github.com/vikasnkumar/hotpatch</a> <br /> </div>