6

编辑:如果它的 TLDR,就跳到底部。我在哪里问:如何配置 autotools 项目以使用静态库?

我正在使用几个开源库,并且正在尝试在 Clang 的消毒剂下运行他们的测试套件。要在 Clang sanitizers 下运行,我们需要 (1) 指定一些选项,以及 (2) 根据需要从 Clang 的 Compiler-RT 链接静态库。注意:没有动态库或共享对象。

设置选项很容易:

export DYLD_FALLBACK_LIBRARY_PATH=/usr/local/lib/clang/3.3/lib/darwin/
export CC=/usr/local/bin/clang
export CXX=/usr/local/bin/clang++
export CFLAGS="-g3 -fsanitize=address -fsanitize=undefined"
export CXXFLAGS="-g3 -fsanitize=address -fsanitize=undefined -fno-sanitize=vptr"

./configure

但是,这将生成一些存档警告(何时AR运行)和链接错误(何时LD运行)带有未定义的符号。该消息将类似于:

libjpeg.a(jmemmgr.o): In function `do_sarray_io':
/home/jwalton/jpeg-6b/jmemmgr.c:695: undefined reference to
`__ubsan_handle_type_mismatch'
/home/jwalton/jpeg-6b/jmemmgr.c:695: undefined reference to
`__ubsan_handle_type_mismatch'
/home/jwalton/jpeg-6b/jmemmgr.c:696: undefined reference to
`__ubsan_handle_type_mismatch'

我知道需要链接的库。对于我使用的消毒剂,它们是libclang_rt.asan_osx.aand libclang_rt.ubsan_osx.a(或libclang_rt.full-x86_64.alibclang_rt.ubsan-x86_64.aLinux 上)。

为了提供库,我然后导出以下内容。注意:它是LIBS,而不是LDLIBS像大多数其他make相关工具所期望的那样。

export LIBS="/usr/local/lib/clang/3.3/lib/darwin/libclang_rt.asan_osx.a \
             /usr/local/lib/clang/3.3/lib/darwin/libclang_rt.ubsan_osx.a"

这会导致以下configure问题:

configure: error: cannot run C compiled programs.
If you meant to cross compile, use `--host'.
...

看起来config.log,似乎出现了两个问题。首先,路径被从 更改/usr/local/.../Users/jwalton/...。其次,通过从静态库更改为动态库,文件名被屠杀:

configure:3346: ./conftest
dyld: Library not loaded: /Users/jwalton/clang-llvm/llvm-3.3.src/Release+Asserts/lib/clang/3.3/lib/darwin/libclang_rt.asan_osx_dynamic.dylib
  Referenced from: /Users/jwalton/libpng-1.6.7/./conftest
Reason: image not found

在另一次尝试中,我尝试使用LDFLAGS

export LDFLAGS="-L/usr/local/lib/clang/3.3/lib/darwin/"
export LIBS="libclang_rt.asan_osx.a libclang_rt.ubsan_osx.a"

这会导致类似的错误:

configure: error: in `/Users/jwalton/libpng-1.6.7':
configure: error: C compiler cannot create executables

并且config.log

configure:3209: /usr/local/bin/clang -g3 -fsanitize=address -fsanitize=undefined  -L/usr/local/lib/clang/3.3/lib/darwin/ conftest.c libclang_rt.asan_osx.a libclang_rt.ubsan_osx.a >&5
clang: error: no such file or directory: 'libclang_rt.asan_osx.a'
clang: error: no such file or directory: 'libclang_rt.ubsan_osx.a'

并从结果中删除lib前缀和.a后缀:LIBS

configure:3209: /usr/local/bin/clang -g3 -fsanitize=address -fsanitize=undefined  -L/usr/local/lib/clang/3.3/lib/darwin/ conftest.c clang_rt.asan_osx clang_rt.ubsan_osx >&5
clang: error: no such file or directory: 'clang_rt.asan_osx'
clang: error: no such file or directory: 'clang_rt.ubsan_osx'

并将结果添加-lLIBS

configure:3335: /usr/local/bin/clang -o conftest -g3 -fsanitize=address -fsanitize=undefined  
    -L/usr/local/lib/clang/3.3/lib/darwin/ conftest.c -lclang_rt.asan_osx -lclang_rt.ubsan_osx >&5
configure:3339: $? = 0
configure:3346: ./conftest
dyld: could not load inserted library: /Users/jwalton/libpng-1.6.7/./conftest

./configure: line 3348: 38224 Trace/BPT trap: 5       ./conftest$ac_cv_exeext

最后,-L论证是有效的:

$ ls /usr/local/lib/clang/3.3/lib/darwin/
libclang_rt.10.4.a          libclang_rt.ios.a
libclang_rt.asan_osx.a          libclang_rt.osx.a
libclang_rt.asan_osx_dynamic.dylib  libclang_rt.profile_ios.a
libclang_rt.cc_kext.a           libclang_rt.profile_osx.a
libclang_rt.cc_kext_ios5.a      libclang_rt.ubsan_osx.a
libclang_rt.eprintf.a

毕竟背景:我如何配置一个 autotools 项目以使用静态库?

奖励积分:为什么这么容易的事情变得如此困难?

4

3 回答 3

5

您还需要将 -fsanitize 标志添加到 LDFLAGS。

于 2013-12-19T14:49:36.530 回答
3

GNU libtool 的发布版本不会将 -fsanitize=... 参数传递给链接器。您需要使用来自http://savannah.gnu.org/patch/?8775的补丁更新 libtool 具体:

diff --git a/build-aux/ltmain.in b/build-aux/ltmain.in
index 0c40da0..b99b0cd 100644
--- a/build-aux/ltmain.in
+++ b/build-aux/ltmain.in
@@ -5362,10 +5362,11 @@ func_mode_link ()
       # -O*, -g*, -flto*, -fwhopr*, -fuse-linker-plugin GCC link-time optimization
       # -specs=*             GCC specs files
       # -stdlib=*            select c++ std lib with clang
+      # -fsanitize=*         Clang memory and address sanitizer
       -64|-mips[0-9]|-r[0-9][0-9]*|-xarch=*|-xtarget=*|+DA*|+DD*|-q*|-m*| \
       -t[45]*|-txscale*|-p|-pg|--coverage|-fprofile-*|-F*|@*|-tp=*|--sysroot=*| \
       -O*|-g*|-flto*|-fwhopr*|-fuse-linker-plugin|-fstack-protector*|-stdlib=*| \
-      -specs=*)
+      -specs=*|-fsanitize=*)
         func_quote_for_eval "$arg"
    arg=$func_quote_for_eval_result
         func_append compile_command " $arg"

至于让 libtool 接受静态库,您应该能够在命令行中仅包含静态库的完整路径,或者您可以使用-L/usr/local/lib/clang/3.3/lib/darwin/ -lclang_rt.ubsan_osx. 但是,一旦 libtool 告诉它使用 -fsanitize=... 进行链接,cfe 应该为您处理库魔法。

于 2015-10-19T18:38:53.500 回答
0

至于未定义的符号问题,如果您正在链接 C++ 对象,那么您必须使用clang++而不是clang. 否则你会得到错误,例如:

/bin/bash libtool --tag=CC --mode=link clang-3.6 ... -fsanitize=undefined -o freeswitch ...
libtool: link: clang-3.6 ... -fsanitize=undefined -o .libs/freeswitch ./.libs/libfreeswitch.so ...
./.libs/libfreeswitch.so: undefined reference to `__ubsan_vptr_type_cache'
./.libs/libfreeswitch.so: undefined reference to `__ubsan_handle_dynamic_type_cache_miss'
clang: error: linker command failed with exit code 1 (use -v to see invocation)

在上面的例子中,atrociouslibtool使用了 clang 而不是 clang++,因为automake它认为你想链接一组 C 对象(它不理解libfreeswitch.la使用 C++ 链接 libtool 存档()意味着需要一个 C++ 链接器(注意--tag=CC)。另请参阅https://lists.debian.org/debian-mentors/2003/06/msg00004.html

要解决此问题,请按照https://www.gnu.org/software/automake/manual/html_node/Libtool-Convenience-Libraries.html中的说明在您的源代码中添加(虚拟/真实)C++ 源代码Makefile.am

SUBDIRS = sub1 sub2 …
lib_LTLIBRARIES = libtop.la
libtop_la_SOURCES =
# Dummy C++ source to cause C++ linking.
nodist_EXTRA_libtop_la_SOURCES = dummy.cxx
libtop_la_LIBADD = \
  sub1/libsub1.la \
  sub2/libsub2.la \
  …
于 2015-07-22T23:09:04.120 回答