簡體   English   中英

如何使用 ltrace 跟蹤動態加載的庫調用

[英]How to trace dynamically loaded library calls with ltrace

我有一個 C 程序使用動態加載的庫來加載插件。 我想跟蹤庫調用以調試插件的加載。

我查看了ltrace ,但似乎無法使其工作:

這是一個示例程序:

#include <stdio.h>
#include <stdlib.h>

#include <dlfcn.h>

int main() {
    int *a = malloc(sizeof(int));
    void *handle;
    double (*cosine)(double);
    char *error;

    handle = dlopen ("/usr/lib/x86_64-linux-gnu/libm.so.6", RTLD_LAZY);
    if (!handle) {
        fputs (dlerror(), stderr);
        exit(1);
    }

    cosine = dlsym(handle, "cos");
    if ((error = dlerror()) != NULL)  {
        fputs(error, stderr);
        exit(1);
    }

    printf ("%f\n", (*cosine)(2.0));
    dlclose(handle);
    return 0;
}

編譯(並刪除PIE ,否則 ltrace 將看不到任何內容): gcc main.c -pg -ldl -no-pie

運行: ltrace./a.out

Output

__monstartup(0x401170, 0x401431, 0x7fffe3875838, 0x7fffe3875838)                                                               = 0
__cxa_atexit(0x7f712aa98ba0, 0, 0, 0)                                                                                          = 0
malloc(4)                                                                                                                      = 0x76ea30
dlopen("/usr/lib/x86_64-linux-gnu/libm.s"..., 1)                                                                               = 0x76ea80
dlsym(0x76ea80, "cos")                                                                                                         = 0x7f712a8abd00
dlerror()                                                                                                                      = nil
printf("%f\n", -0.416147-0.416147
)                                                                                                      = 10
dlclose(0x76ea80)                                                                                                              = 0
+++ exited (status 0) +++

如您所見,對cos的調用被跳過了。 我怎樣才能用那個 arguments 追蹤它?

我嘗試了uftrace

但同樣,它沒有跟蹤cos調用:

uftrace -a --libname --nest-libcall ./a.out
-0.416147
# DURATION     TID     FUNCTION
            [  8300] | main() {
   1.754 us [  8300] |   malloc@libc-2.31.so(4) = 0x15c6120;
 509.774 us [  8300] |   dlopen@libdl-2.31.so("/usr/lib/x86_64-linux-gnu/libm.so.6", RTLD_LAZY) = 0x7ff70ae4d090;
   2.140 us [  8300] |   dlsym@libdl-2.31.so(0x7ff70ae4d090, "cos") = 0x7ff70aa61d00;
   0.463 us [  8300] |   dlerror@libdl-2.31.so() = "NULL";
 332.451 us [  8300] |   printf@libc-2.31.so("%f\n") = 10;
   2.134 us [  8300] |   dlclose@libdl-2.31.so(0x7ff70ae4d090) = 0;
 958.926 us [  8300] | } /*

這很令人驚訝,因為在這個評論中它看起來很有效。

在 Ubuntu 20.04 上運行

  • ltrace: 0.7.3
  • uftrace: 0.9.3

謝謝您的幫助 !

您需要添加一個特殊的標志-x pattern來強制跟蹤dlopen -ed 庫中的符號(最簡單的是-x '*' ,有關更多詳細信息,請參閱@nayana 的答案。)

舊版本的ltrace不包括https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=537781的相關補丁(點擊鏈接到dlopen ),因此他們無法跟蹤 libd .

在這種情況下, yugr的答案是最相關的。 然而,即使將 ltrace 與補丁一起使用,其用法也不是直截了當的。

重要的部分是使用-x選項,否則通過 dlopen 加載的庫中的符號將不會顯示。 新聞中說明了這一事實:

*** 支持跟蹤使用 dlopen 打開的庫中的符號

這些符號由-x 選擇。

幸運的是,我們可以將其設置為顯示與我們的庫地址匹配的所有符號,這是通過使用 ltrace 手冊頁中描述的特殊glob格式來實現的。

我的用例是調試通過 dlopen 加載的自定義 alsa-lib 插件:

# ltrace -x "@libdl.so.2" -x "*@libcustom.so" -f aplay -D custom test.wav
[pid 4183] snd_pcm_hw_params(0x5598dc8ce0, 0x7fe4d76fe0, 0xa3377eac3f8c3d00, 0 <unfinished ...>
[pid 4183] dlopen@libdl.so.2(0x5598dc5db0, 1, 0x5598dc8a4c, 0 <unfinished ...>
[pid 4183] _init@libdirac_dldsp.so(4, 0x7fe4d77858, 0x7fe4d77880, 0x7fa61ce0d8 <unfinished ...>
....
[pid 4183] dlsym@libdl.so.2(0x5598dc8ef0, 0x7fa65b1e48, 1, 0)                                                                                      = 0x7fa61cf890
[pid 4183] dl_descriptor@libcustom.so(0x7fa61cf890, 0, 0x7fa6627988, 1)                                                                       = 0x7fa61fe9e8
.....
[pid 4183] custom_lib_init@libcustom.so(0x7fe4d76770, 0x7fa61ffaf0, 0, 0 <unfinished ...>
[pid 4183] custom_init@libcustom.so(0x7fe4d76770, 1, 3, 0)                                                                                      = 0
....

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM