10

「尋問」と呼ばれる実行可能ファイルを次のようにコンパイルしています。

g++ -o built/bin/interrogate -Lbuilt/lib -Lbuilt/tmp -L/usr/X11R6/lib \
built/tmp/interrogate_composite1.o built/tmp/interrogate_composite2.o \
-lp3cppParser -lp3dtool -lp3dtoolconfig -lp3pystub -pthread -ldl

コンパイル後、実行可能ファイルを実行しようとすると:

$ LD_LIBRARY_PATH=built/lib built/bin/interrogate
built/bin/interrogate: シンボル検索エラー: built/lib/libp3dtool.so.1.8: 未定義のシンボル: _Py_NoneStruct

このシンボルは libp3pystub.so によって提供されますが、尋問実行可能ファイルにはこのライブラリへの参照がありません (私は -lp3pystub を使用しました)。

$ LD_LIBRARY_PATH=built/lib ldd built/bin/interrogate
    linux-vdso.so.1 => (0x00007fff2016a000)
    libp3dtool.so.1.8 => built/lib/libp3dtool.so.1.8 (0x00007f498d57a000)
    libp3dtoolconfig.so.1.8 => built/lib/libp3dtoolconfig.so.1.8 (0x00007f498d51b000)
    libstdc++.so.6 => /usr/lib/x86_64-linux-gnu/libstdc++.so.6 (0x00007f498d1f2000)
    libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007f498cfdc000)
    libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007f498cdbf000)
    libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f498c9ff000)
    libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007f498c7fb000)
    libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007f498c4ff000)
    /lib64/ld-linux-x86-64.so.2 (0x00007f498d5bc000)

libp3pystub.so を手動でロードすると、実行可能ファイルが機能します。

$ LD_PRELOAD=built/lib/libp3pystub.so LD_LIBRARY_PATH=built/lib built/bin/interrogate

使用法:
  尋問 [opts] file.C [file.C ...]
  問い合わせ -h

私の質問は、追加したライブラリが実行可能ファイル-lp3pystubによって参照されないのはなぜですか?interrogate

4

1 に答える 1

16

私は実際に自分で答えを見つけます。私はUbuntuでコンパイルしていましたが、デフォルトの最適化フラグが追加されました: -Wl,--as-needed. この最適化は、-l で渡されたライブラリのシンボルがメインの実行可能ファイルで使用されていないかどうかをチェックし、それらは削除されます。

_Py_NoneStruct は、尋問によって直接使用されるのではなく、別の共有ライブラリによって使用されます。したがって、p3pystub が必要であることを手動で指定する必要があります。

考えられる修正の1つは次のとおりです。

$ g++ -o built/bin/interrogate -Lbuilt/lib -Lbuilt/tmp -L/usr/X11R6/lib \
built/tmp/interrogate_composite1.o built/tmp/interrogate_composite2.o \
-Wl,--no-as-needed -lp3cppParser -lp3dtool -lp3dtoolconfig -lp3pystub \
-pthread -ldl

そして、ldd出力でライブラリを正しく取得しました:

$ LD_LIBRARY_PATH=built/lib ldd built/bin/interrogate
    linux-vdso.so.1 => (0x00007fff0edff000)
    libp3dtool.so.1.8 => built/lib/libp3dtool.so.1.8 (0x00007fa1c36be000)
    libp3dtoolconfig.so.1.8 => built/lib/libp3dtoolconfig.so.1.8 (0x00007fa1c365f000)
>>> libp3pystub.so.1.8 => built/lib/libp3pystub.so.1.8 (0x00007fa1c3658000)
    libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007fa1c342f000)
    libstdc++.so.6 => /usr/lib/x86_64-linux-gnu/libstdc++.so.6 (0x00007fa1c312c000)
    libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007fa1c2e2f000)
    libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007fa1c2c19000)
    libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007fa1c29fc000)
    libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007fa1c263c000)
    /lib64/ld-linux-x86-64.so.2 (0x00007fa1c3700000)

参照: https://wiki.ubuntu.com/NattyNarwhal/ToolchainTransition

于 2013-01-15T02:32:08.833 に答える