РЕДАКТИРОВАНИЕ: если это TLDR, просто пропустите его вниз. Здесь я спрашиваю: Как мне настроить проект autotools для использования статической библиотеки?
Я работаю с парой библиотек с открытым исходным кодом и пытаюсь запустить их набор тестов под дезинфицирующими средствами Clang. Чтобы работать под дезинфицирующими средствами Clang, нам нужно (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.a
и libclang_rt.ubsan_osx.a
(или libclang_rt.full-x86_64.a
и libclang_rt.ubsan-x86_64.a
в Linux).
Чтобы предоставить библиотеки, я экспортирую следующее. Примечание: это 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'
И добавление -l
к LIBS
приводит к:
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 для использования статической библиотеки?
Бонусные баллы: почему что-то настолько простое стало таким сложным?