From 77b89dbc9f9f965ad0ef2e341d7d46bce5f07549 Mon Sep 17 00:00:00 2001 From: Hongxu Jia Date: Fri, 23 Aug 2019 10:17:25 +0800 Subject: [PATCH 1/3] musl-obstack-fts Look for libfts and libobstack during configure, these libraries are external to libc when using musl, whereas on glibc these libraries are provided in libc itself. Signed-off-by: Khem Raj Upstream-Status: Inappropriate [workaround for musl] Rebase to 0.177 Signed-off-by: Hongxu Jia --- configure.ac | 54 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ libdw/Makefile.am | 2 +- src/Makefile.am | 8 ++++---- 3 files changed, 59 insertions(+), 5 deletions(-) diff --git a/configure.ac b/configure.ac index f93964c..b87b762 100644 --- a/configure.ac +++ b/configure.ac @@ -494,6 +494,60 @@ else fi AC_SUBST([argp_LDADD]) +dnl Check if we have fts available from our libc +AC_LINK_IFELSE( + [AC_LANG_PROGRAM( + [#if !defined(__x86_64__) + #undef _FILE_OFFSET_BITS + #define _FILE_OFFSET_BITS 32 + #endif + #include ], + [FTS* fts = 0; return fts_close(fts); return 0;] + )], + [libc_has_fts="true"], + [libc_has_fts="false"] +) + +dnl If our libc doesn't provide fts, then test for libfts +if test "$libc_has_fts" = "false" ; then + AC_MSG_WARN("libc does not have fts") + AC_CHECK_LIB([fts], [fts_close], [have_fts="true"], [have_fts="false"]) + + if test "$have_fts" = "false"; then + AC_MSG_ERROR("no libfts found") + else + fts_LDADD="-lfts" + fi +else + fts_LDADD="" +fi +AC_SUBST([fts_LDADD]) + +dnl Check if we have obstack available from our libc +AC_LINK_IFELSE( + [AC_LANG_PROGRAM( + [#include ], + [_obstack_begin(0, 0, 0, NULL, NULL); return 0;] + )], + [libc_has_obstack="true"], + [libc_has_obstack="false"] +) + +dnl If our libc doesn't provide obstack, then test for libobstack +if test "$libc_has_obstack" = "false" ; then + AC_MSG_WARN("libc does not have obstack") + AC_CHECK_LIB([obstack], [_obstack_begin], [have_obstack="true"], [have_obstack="false"]) + + if test "$have_obstack" = "false"; then + AC_MSG_ERROR("no libobstack found") + else + obstack_LDADD="-lobstack" + fi +else + obstack_LDADD="" +fi +AC_SUBST([obstack_LDADD]) + dnl The directories with content. dnl Documentation. diff --git a/libdw/Makefile.am b/libdw/Makefile.am index 7a3d532..a541fa3 100644 --- a/libdw/Makefile.am +++ b/libdw/Makefile.am @@ -108,7 +108,7 @@ am_libdw_pic_a_OBJECTS = $(libdw_a_SOURCES:.c=.os) libdw_so_LIBS = libdw_pic.a ../libdwelf/libdwelf_pic.a \ ../libdwfl/libdwfl_pic.a ../libebl/libebl.a libdw_so_DEPS = ../lib/libeu.a ../libelf/libelf.so -libdw_so_LDLIBS = $(libdw_so_DEPS) -ldl -lz $(argp_LDADD) $(zip_LIBS) +libdw_so_LDLIBS = $(libdw_so_DEPS) -ldl -lz $(argp_LDADD) $(fts_LDADD) $(zip_LIBS) libdw_so_SOURCES = libdw.so$(EXEEXT): $(srcdir)/libdw.map $(libdw_so_LIBS) $(libdw_so_DEPS) # The rpath is necessary for libebl because its $ORIGIN use will diff --git a/src/Makefile.am b/src/Makefile.am index b72f853..2f3dfce 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -69,8 +69,8 @@ ar_no_Wstack_usage = yes unstrip_no_Wstack_usage = yes readelf_LDADD = $(libdw) $(libebl) $(libelf) $(libeu) $(argp_LDADD) -ldl -nm_LDADD = $(libdw) $(libebl) $(libelf) $(libeu) $(argp_LDADD) -ldl \ - $(demanglelib) +nm_LDADD = $(libdw) $(libebl) $(libelf) $(libeu) $(argp_LDADD) \ + $(obstack_LDADD) -ldl $(demanglelib) size_LDADD = $(libelf) $(libeu) $(argp_LDADD) strip_LDADD = $(libebl) $(libelf) $(libdw) $(libeu) $(argp_LDADD) -ldl elflint_LDADD = $(libebl) $(libelf) $(libeu) $(argp_LDADD) -ldl @@ -78,9 +78,9 @@ findtextrel_LDADD = $(libdw) $(libelf) $(libeu) $(argp_LDADD) addr2line_LDADD = $(libdw) $(libelf) $(libeu) $(argp_LDADD) $(demanglelib) elfcmp_LDADD = $(libebl) $(libelf) $(libeu) $(argp_LDADD) -ldl objdump_LDADD = $(libasm) $(libebl) $(libelf) $(libeu) $(argp_LDADD) -ldl -ranlib_LDADD = libar.a $(libelf) $(libeu) $(argp_LDADD) +ranlib_LDADD = libar.a $(libelf) $(libeu) $(argp_LDADD) $(obstack_LDADD) strings_LDADD = $(libelf) $(libeu) $(argp_LDADD) -ar_LDADD = libar.a $(libelf) $(libeu) $(argp_LDADD) +ar_LDADD = libar.a $(libelf) $(libeu) $(argp_LDADD) $(obstack_LDADD) unstrip_LDADD = $(libebl) $(libelf) $(libdw) $(libeu) $(argp_LDADD) -ldl stack_LDADD = $(libebl) $(libelf) $(libdw) $(libeu) $(argp_LDADD) -ldl $(demanglelib) elfcompress_LDADD = $(libebl) $(libelf) $(libdw) $(libeu) $(argp_LDADD) -- 2.7.4