解决交叉编译连接器包含-ldl编译选项,但仍然报错undefined reference to ‘__dlsym‘

交叉编译连接器包含-ldl编译选项,但仍然报错undefined reference to ‘__dlsym‘

问题排查

为TX2交叉编译最新版本的BehaviorTree.Cpp库,使用cmake第一次编译BehaviorTree.Cpp的时候,生成behaviortree_cpp_v3.so时报出警告

warning: Using 'dlopen' in statically linked applications requires at runtime the shared library from the glibc version used for linking

虽然报出了这个警告,但是至少behaviortree_cpp_v3.so是生成出来了,只是后面的几个测试程序生成却报错:

../libbehaviortree_cpp_v3.so: undefined reference to '__dlsym'
../libbehaviortree_cpp_v3.so: undefined reference to '__dlopen'
../libbehaviortree_cpp_v3.so: undefined reference to '__dlclose'
../libbehaviortree_cpp_v3.so: undefined reference to '__dlerror'

不仅如此,将这个有问题的libbehaviortree_cpp_v3.so拿去给自己的程序使用仍然报找不到符号的错误。
去tx2的sysroot中找libdl.so
发现在/lib/aarch64-linux-gnu/libdl.so.2,查看导出动态链接符号

$ objdump -T libdl.so.2
0000000000000000 g    DO  .text  00000000000000cc  GLIBC_2.17  dlsym
0000000000000000 g    DO  .text  000000000000002c  GLIBC_2.17  dladdr

libdl.so则在tx2的sysroot中的/usr/lib/aarch64-linux-gnu/libdl.so

问题出在这里
libdl.so指向了/lib/aarch64-linux-gnu/libdl.so.2,这在TX2目标机上运行是没问题的,但是在host中,根本不存在这个文件。
交叉编译工具链需要的是包含了tx2-sysroot的位置即${tx2-sysroot}/lib/aarch64-linux-gnu/libdl.so.2
为了能够兼容目标和主机,修正libdl.so符号链接ln -sf ../../../lib/aarch64-linux-gnu/libdl.so.2 libdl.so.2

再次重新编译BehaviorTree.CPP一切正常。

成因

回顾前面在编译libbehaviortree_cpp_v3.so的时候报出的警告

warning: Using 'dlopen' in statically linked applications requires at runtime the shared library from the glibc version used for linking

其实已经提示了,没有找到动态库,作为代替使用了/lib/aarch64-linux-gnu/libdl.a,但静态库的符号默认是位置相关的,并且其符号名也是另外一套规则

$ objdump -t libdl.a
dlsym.o:        file format elf64-little

SYMBOL TABLE:
0000000000000000 l       .text  0000000000000000 $x
0000000000000000 l    d  .text  0000000000000000 .text
0000000000000000 l    d  .data  0000000000000000 .data
0000000000000000 l    d  .bss   0000000000000000 .bss
0000000000000000 l    d  .note.GNU-stack  0000000000000000 .note.GNU-stack
0000000000000000  w    F .text  0000000000000000 dlsym
0000000000000000         *UND*  0000000000000000 __dlsym

看到那个__dlsym了没有

反思

说过无数次不要忽视任何警告,对待警告,就要如同对待错误一样。这次出现的问题再一次印证了这句话。

################################################################################ # # libopenssl # ################################################################################ LIBOPENSSL_VERSION = 1.1.1n LIBOPENSSL_SITE = https://www.openssl.org/source LIBOPENSSL_SOURCE = openssl-$(LIBOPENSSL_VERSION).tar.gz LIBOPENSSL_LICENSE = OpenSSL or SSLeay LIBOPENSSL_LICENSE_FILES = LICENSE LIBOPENSSL_INSTALL_STAGING = YES LIBOPENSSL_DEPENDENCIES = zlib HOST_LIBOPENSSL_DEPENDENCIES = host-zlib LIBOPENSSL_TARGET_ARCH = $(call qstrip,$(BR2_PACKAGE_LIBOPENSSL_TARGET_ARCH)) LIBOPENSSL_CFLAGS = $(TARGET_CFLAGS) LIBOPENSSL_PROVIDES = openssl LIBOPENSSL_CPE_ID_VENDOR = $(LIBOPENSSL_PROVIDES) LIBOPENSSL_CPE_ID_PRODUCT = $(LIBOPENSSL_PROVIDES) ifeq ($(BR2_m68k_cf),y) # relocation truncated to fit: R_68K_GOT16O LIBOPENSSL_CFLAGS += -mxgot # resolves an assembler "out of range error" with blake2 and sha512 algorithms LIBOPENSSL_CFLAGS += -DOPENSSL_SMALL_FOOTPRINT endif ifeq ($(BR2_USE_MMU),) LIBOPENSSL_CFLAGS += -DHAVE_FORK=0 -DOPENSSL_NO_MADVISE endif ifeq ($(BR2_PACKAGE_HAS_CRYPTODEV),y) LIBOPENSSL_DEPENDENCIES += cryptodev endif # fixes the following build failures: # # - musl # ./libcrypto.so: undefined reference to `getcontext' # ./libcrypto.so: undefined reference to `setcontext' # ./libcrypto.so: undefined reference to `makecontext' # # - uclibc: # crypto/async/arch/../arch/async_posix.h:32:5: error: unknown type name 'ucontext_t' # ifeq ($(BR2_TOOLCHAIN_USES_MUSL),y) LIBOPENSSL_CFLAGS += -DOPENSSL_NO_ASYNC endif ifeq ($(BR2_TOOLCHAIN_HAS_UCONTEXT),) LIBOPENSSL_CFLAGS += -DOPENSSL_NO_ASYNC endif define HOST_LIBOPENSSL_CONFIGURE_CMDS (cd $(@D); \ $(HOST_CONFIGURE_OPTS) \ ./config \ --prefix=$(HOST_DIR) \ --openssldir=$(HOST_DIR)/etc/ssl \ no-tests \ no-fuzz-libfuzzer \ no-fuzz-afl \ shared \ zlib-dynamic \ ) $(SED) "s#-O[0-9sg]#$(HOST_CFLAGS)#" $(@D)/Makefile endef define LIBOPENSSL_CONFIGURE_CMDS (cd $(@D); \ $(TARGET_CONFIGURE_ARGS) \ $(TARGET_CONFIGURE_OPTS) \ ./Configure \ $(LIBOPENSSL_TARGET_ARCH) \ --prefix=/usr \ --openssldir=/etc/ssl \ $(if $(BR2_TOOLCHAIN_HAS_LIBATOMIC),-latomic) \ $(if $(BR2_TOOLCHAIN_HAS_THREADS),threads,no-threads) \ $(if $(BR2_STATIC_LIBS),no-shared,shared) \ $(if $(BR2_PACKAGE_HAS_CRYPTODEV),enable-devcryptoeng) \ no-rc5 \ enable-camellia \ enable-mdc2 \ enable-rc4 \ enable-des \ enable-weak-ssl-ciphers \ no-tests \ no-fuzz-libfuzzer \ no-fuzz-afl \ $(if $(BR2_PACKAGE_LIBOPENSSL_ENABLE_CHACHA),,no-chacha) \ $(if $(BR2_PACKAGE_LIBOPENSSL_ENABLE_RC5),,no-rc5) \ $(if $(BR2_PACKAGE_LIBOPENSSL_ENABLE_RC2),,no-rc2) \ $(if $(BR2_PACKAGE_LIBOPENSSL_ENABLE_RC4),,no-rc4) \ $(if $(BR2_PACKAGE_LIBOPENSSL_ENABLE_MD2),,no-md2) \ $(if $(BR2_PACKAGE_LIBOPENSSL_ENABLE_MD4),,no-md4) \ $(if $(BR2_PACKAGE_LIBOPENSSL_ENABLE_MDC2),,no-mdc2) \ $(if $(BR2_PACKAGE_LIBOPENSSL_ENABLE_BLAKE2),,no-blake2) \ $(if $(BR2_PACKAGE_LIBOPENSSL_ENABLE_IDEA),,no-idea) \ $(if $(BR2_PACKAGE_LIBOPENSSL_ENABLE_SEED),,no-seed) \ $(if $(BR2_PACKAGE_LIBOPENSSL_ENABLE_DES),,no-des) \ $(if $(BR2_PACKAGE_LIBOPENSSL_ENABLE_RMD160),,no-rmd160) \ $(if $(BR2_PACKAGE_LIBOPENSSL_ENABLE_WHIRLPOOL),,no-whirlpool) \ $(if $(BR2_PACKAGE_LIBOPENSSL_ENABLE_BLOWFISH),,no-bf) \ $(if $(BR2_PACKAGE_LIBOPENSSL_ENABLE_SSL),,no-ssl) \ $(if $(BR2_PACKAGE_LIBOPENSSL_ENABLE_SSL2),,no-ssl2) \ $(if $(BR2_PACKAGE_LIBOPENSSL_ENABLE_SSL3),,no-ssl3) \ $(if $(BR2_PACKAGE_LIBOPENSSL_ENABLE_WEAK_SSL),,no-weak-ssl-ciphers) \ $(if $(BR2_PACKAGE_LIBOPENSSL_ENABLE_PSK),,no-psk) \ $(if $(BR2_PACKAGE_LIBOPENSSL_ENABLE_CAST),,no-cast) \ $(if $(BR2_PACKAGE_LIBOPENSSL_UNSECURE),,no-unit-test no-crypto-mdebug-backtrace no-crypto-mdebug no-autoerrinit) \ $(if $(BR2_PACKAGE_LIBOPENSSL_DYNAMIC_ENGINE),,no-dynamic-engine ) \ $(if $(BR2_PACKAGE_LIBOPENSSL_ENABLE_COMP),,no-comp) \ $(if $(BR2_STATIC_LIBS),zlib,zlib-dynamic) \ $(if $(BR2_STATIC_LIBS),no-dso) \ ) $(SED) "s#-march=[-a-z0-9] ##" -e "s#-mcpu=[-a-z0-9] ##g" $(@D)/Makefile $(SED) "s#-O[0-9sg]#$(LIBOPENSSL_CFLAGS)#" $(@D)/Makefile $(SED) "s# build_tests##" $(@D)/Makefile endef # libdl is not available in a static build, and this is not implied by no-dso ifeq ($(BR2_STATIC_LIBS),y) define LIBOPENSSL_FIXUP_STATIC_MAKEFILE $(SED) 's#-ldl##g' $(@D)/Makefile endef LIBOPENSSL_POST_CONFIGURE_HOOKS += LIBOPENSSL_FIXUP_STATIC_MAKEFILE endif define HOST_LIBOPENSSL_BUILD_CMDS $(HOST_MAKE_ENV) $(MAKE) -C $(@D) endef define LIBOPENSSL_BUILD_CMDS $(TARGET_MAKE_ENV) $(MAKE) -C $(@D) endef define LIBOPENSSL_INSTALL_STAGING_CMDS $(TARGET_MAKE_ENV) $(MAKE) -C $(@D) DESTDIR=$(STAGING_DIR) install endef define HOST_LIBOPENSSL_INSTALL_CMDS $(HOST_MAKE_ENV) $(MAKE) -C $(@D) install endef define LIBOPENSSL_INSTALL_TARGET_CMDS $(TARGET_MAKE_ENV) $(MAKE) -C $(@D) DESTDIR=$(TARGET_DIR) install rm -rf $(TARGET_DIR)/usr/lib/ssl rm -f $(TARGET_DIR)/usr/bin/c_rehash endef # libdl has no business in a static build ifeq ($(BR2_STATIC_LIBS),y) define LIBOPENSSL_FIXUP_STATIC_PKGCONFIG $(SED) 's#-ldl##' $(STAGING_DIR)/usr/lib/pkgconfig/libcrypto.pc $(SED) 's#-ldl##' $(STAGING_DIR)/usr/lib/pkgconfig/libssl.pc $(SED) 's#-ldl##' $(STAGING_DIR)/usr/lib/pkgconfig/openssl.pc endef LIBOPENSSL_POST_INSTALL_STAGING_HOOKS += LIBOPENSSL_FIXUP_STATIC_PKGCONFIG endif ifeq ($(BR2_PACKAGE_PERL),) define LIBOPENSSL_REMOVE_PERL_SCRIPTS $(RM) -f $(TARGET_DIR)/etc/ssl/misc/{CA.pl,tsget} endef LIBOPENSSL_POST_INSTALL_TARGET_HOOKS += LIBOPENSSL_REMOVE_PERL_SCRIPTS endif ifeq ($(BR2_PACKAGE_LIBOPENSSL_BIN),) define LIBOPENSSL_REMOVE_BIN $(RM) -f $(TARGET_DIR)/usr/bin/openssl $(RM) -f $(TARGET_DIR)/etc/ssl/misc/{CA.*,c_*} endef LIBOPENSSL_POST_INSTALL_TARGET_HOOKS += LIBOPENSSL_REMOVE_BIN endif ifneq ($(BR2_PACKAGE_LIBOPENSSL_ENGINES),y) define LIBOPENSSL_REMOVE_LIBOPENSSL_ENGINES rm -rf $(TARGET_DIR)/usr/lib/engines-1.1 endef LIBOPENSSL_POST_INSTALL_TARGET_HOOKS += LIBOPENSSL_REMOVE_LIBOPENSSL_ENGINES endif $(eval $(generic-package)) $(eval $(host-generic-package)) 分析这个对libopenssl进行编译的.mk文件,做了什么
最新发布
12-21
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值