バイナリを計測するための pintool を作成しています。
命令に関する情報を保存するために sqlite3 データベースを使用したいと思います。
問題なく sqlite3 の "helloworld" の例をコンパイルして実行できます。同様に、sqlite 接続なしで pintool をコンパイルして実行できます。ただし、pintool に sqlite コードを統合するたびにエラーが発生します。
dlopen に失敗しました: ライブラリ "libsqlite3.so.0" が見つかりません
正確には何をしますか:
私のリンクコマンドは次のようになります(コンパイルはエラーなしで終了します):
g++ -shared -Wl,--hash-style=sysv /home/roman/Software/pin/intel64/runtime/pincrt/crtbeginS.o -Wl,-Bsymbolic -Wl,--version-script=/home/roman/ Software/pin/source/include/pin/pintool.ver -fabi-version=2 -o obj-intel64/sqliteTest.so obj-intel64/sqliteTest.o -L/home/roman/Software/pin/intel64/runtime/ pincrt -L/home/roman/Software/pin/intel64/lib -L/home/roman/Software/pin/intel64/lib-ext -L/home/roman/Software/pin/extras/xed-intel64/lib - L/usr/lib/i386-linux-gnu -lpin -lxed /home/roman/Software/pin/intel64/runtime/pincrt/crtendS.o -lpin3dwarf -ldl-dynamic -nostdlib -lstlport-dynamic -lm-dynamic - lc-動的-lsqlite3
LDD コマンド ldd obj-intel64/sqliteTest.so を実行すると、次の結果が得られます。
linux-vdso.so.1 => (0x00007fff4f4aa000)
libxed.so => 見つかりません
libpin3dwarf.so => 見つかりません
libdl-dynamic.so => 見つかりません
libstlport-dynamic.so => 見つかりません
libc-dynamic.so => 見つかりません
libsqlite3.so.0 => /usr/lib/x86_64-linux-gnu/libsqlite3.so.0 (0x00007fd46221f000)
libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007fd462002000)
libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007fd461dfe000)
libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007fd461a34000)
/lib64/ld-linux-x86-64.so.2 (0x000055565d930000)
- シンボル リンク ls -l /usr/lib/x86_64-linux-gnu/libsqlite*:
-rw-r--r-- 1 ルート ルート 1156080 2 月 22 日 17:43 /usr/lib/x86_64-linux-gnu/libsqlite3.a
-rw-r--r-- 1 ルート root 965 Feb 22 17:43 /usr/lib/x86_64-linux-gnu/libsqlite3.la
lrwxrwxrwx 1 root root 19 Feb 22 17:43 /usr/lib/x86_64-linux-gnu/libsqlite3.so -> libsqlite3.so.0.8.6
lrwxrwxrwx 1 root root 19 Feb 22 17:43 /usr/lib/x86_64-linux-gnu/libsqlite3.so.0 -> libsqlite3.so.0.8.6
-rw-r--r-- 1 ルート ルート 870240 2 月 22 日 17:43 /usr/lib/x86_64-linux-gnu/libsqlite3.so.0.8.6
sqlite3 のバージョンは 3.13.0 です
ピンツールを実行すると、次のようになりました。
/home/roman/Software/pin/pin -t /home/roman/Software/pin/source/tools/sqliteTest/obj-intel64/sqliteTest.so -- ./test.bin
E: /home/roman/Software/pin/source/tools/sqliteTest/obj-intel64/sqliteTest.so を読み込めません: dlopen に失敗しました: ライブラリ "libsqlite3.so.0" が見つかりません
コードについて疑問がある場合:
VOID StartApp(VOID *v){ int rc; char nameDB[100]; sprintf(nameDB, "pin_test_0.dat"); rc = sqlite3_open(nameDB, &sqliteDB); if( rc ){ fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(sqliteDB)); return; }else{ fprintf(stderr, "Opened database (%s) successfully\n", nameDB); } sqlite3_close(sqliteDB); //Start random number generator srand(rdtsc()); } ... INT main(int argc, char *argv[]){ if( PIN_Init(argc,argv) ) { return Usage(); } TRACE_AddInstrumentFunction(Trace, 0); PIN_AddApplicationStartFunction(StartApp, 0); PIN_AddFiniFunction(Fini, 0); PIN_StartProgram(); return 0; }
リンク中に -Wl および --verbose オプションを指定すると、次の情報が得られました。
/usr/lib/i386-linux-gnu/libsqlite3.so を開こうとして失敗しました
/usr/lib/i386-linux-gnu/libsqlite3.a を開こうとして失敗しました
/usr/lib/gcc/x86_64-linux-gnu/5/libsqlite3.so を開こうとして失敗しました
/usr/lib/gcc/x86_64-linux-gnu/5/libsqlite3.a を開こうとして失敗しました
/usr/lib/gcc/x86_64-linux-gnu/5/../../../x86_64-linux-gnu/libsqlite3.so を開こうとすると成功しました
-lsqlite3 (/usr/lib/gcc/x86_64-linux-gnu/5/../../../x86_64-linux-gnu/libsqlite3.so)
私の手のどこが悪いのか分かりますか?
どうやらピン v.3 には、私が理解できなかった外部ライブラリの特定の要件があります。ピン v.2.8 にダウングレードすると、すべて正常に動作しました。