【发布时间】:2020-01-22 06:21:32
【问题描述】:
在我们的构建系统中,我们最近将 ASAN 工具(添加 -fsanitize=address)集成到 CFLAGS 以及在链接时创建库 .so 文件。 注意:- 我们使用的是 GCC 6.3 编译器。
我们能够成功构建我们的代码。但是在运行时失败并出现以下问题:
==52215==ASan runtime does not come first in initial library list; you should either link runtime to your application or manually preload it with LD_PRELOAD.
这是我的 gcc 命令:-
/local/common/pkgs/gcc/v6.3.0/bin/gcc -m32 -shared -o /local/testing/build/new_tool/asan_build/syn/verilog/libspd.so -Wl,-rpath=\$ORIGIN/lib -Wl,-rpath=\$ORIGIN/../lib -W1,-rpath=/local/common/gcc/v6.3.0/lib -fsanitize=address -L/local/testing/build/new_tool/asan_build/modules /local/testing/build/new_tool/asan_build/modules/silvpi.o /local/testing/build/new_tool/asan_build/modules/sypsv.o /local/testing/build/new_tool/asan_build/modules/cdnsv_tfs.o /local/testing/build/new_tool/asan_build/modules/libcore.o /local/testing/build/new_tool/asan_build/modules/vpi_user.o /local/testing/build/new_tool/asan_build/modules/libdenbase.a /local/testing/build/new_tool/asan_build/modules/libbdd.a -L/local/testing/build/new_tool/asan_build/syn/lib -L/local/testing/build/new_tool/asan_build/modules -L/home/local/outer/Linux/lib /local/testing/build/new_tool/asan_build/modules/vhpimodelfunc.o /local/testing/build/new_tool/asan_build/modules/vipcommonlib.a -lm -lc -ldenbase -lbdd -ldenbase -lviputil -llocalCommonMT_sh
我能够成功构建库libspd.so。但是当我们尝试运行它时,它会失败并出现上面提到的错误。
可以看到libspd.so的依赖库列表
ldd /local/testing/build/new_tool/asan_build/syn/verilog/libspd.so
linux-gate.so.1 => (0x00279000)
libasan.so.3 => /local/pkgs/gcc/v6.3.0/lib/libasan.so.3 (0xf7175000)
libm.so.6 => /lib/libm.so.6 (0x0014e000)
libc.so.6 => /lib/libc.so.6 (0xf6f83000)
libcdsCommonMT_sh.so => /local/testing/build/new_tool/asan_build/verilog/../lib/liblocalCommonMT_sh.so (0x00178000)
libdl.so.2 => /lib/libdl.so.2 (0x00197000)
我们正在尝试使用“xrun”运行我们的应用程序,它在我使用 asan 构建的构建之上运行模拟。
正如错误所说:you should either link runtime to your application 我试图将完整的 asan 库路径添加到 LD_LIBRARY_PATH,但仍然面临同样的问题。
不知道这里出了什么问题。我该如何解决这个问题?
有什么想法吗?谢谢和问候!
【问题讨论】:
-
主要可执行文件是否也被清理或仅共享库?
-
@yugr,可执行文件,我正在运行并遇到未清理的问题。基于错误,我在我的一个环境文件中设置了指向 libasan.so 路径的 LD_PRELOAD,其中还设置了 LD_LIBRARY_PATH。
-
请提供MVCE。
-
基于文档中的信息:github.com/google/sanitizers/issues/679 有人提到:FWIW 非空 /etc/ld.so.preload 是 GCC 6 不起作用的确切原因(确实是 ASan 运行时不是最初的库列表中的第一个)。 GCC 4.9 之所以有效,是因为它太旧并且没有这种健全性检查。我正在使用 gcc 6.3,我看不到文件文件 /etc/ld.so.preload
标签: gcc gnu-make address-sanitizer