so 動態加載庫 Hotpatch

fmms 13年前發布 | 12K 次閱讀 C 庫

Hotpatch 是一個允許正在運行的進程動態加載一個 so 庫的 C 庫,類似于 Win32 上的 CreateRemoteThread() API。

和其他現有的動態加載方案相比,Hotpatch 的優點是在加載 so 庫之后將會恢復原先進程的運行狀態

開發者可以利用 Hotpatch 實現:

  • 加載 so 庫到一個已經運行的進程中。
  • 調用該 so 庫中的自定義函數。
  • 向該函數傳遞序列化的參數。

它包含三部分: hotpatch.h 頭文件,libhotpatch.so 庫和命令行輔助程序 hotpatcher

目前的局限有:

  • 用戶只能向擁有權限的進程注入 so 庫(當然 root 用戶可以向所有進程注入)。
  • 目前僅支持 64 位 Linux,32 位支持將在下一個版本中完成。
  • 在編譯共享庫時需要加上連接器參數 -fPIC -nostartfiles
  • 對于一個正在運行進程僅能動態加載一次 so 庫文件。
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;
}
項目地址: https://github.com/vikasnkumar/hotpatch
 本文由用戶 fmms 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!