From: Peter O'Gorman Date: Sat, 14 Nov 2009 19:47:10 +0000 (-0600) Subject: Only use preopen loader to load preopened archives X-Git-Tag: v2.2.6b~3 X-Git-Url: http://git.ipfire.org/gitweb/gitweb.cgi?a=commitdiff_plain;h=64da075aba6488dadca1b110d961dcf1ad125f15;p=thirdparty%2Flibtool.git Only use preopen loader to load preopened archives * libltdl/ltdl.c: Limit checking of .a to preopen loader. * tests/lt_dlopen_a.at: Add test. * Makefile.am: Add test. --- diff --git a/ChangeLog b/ChangeLog index 330d2228e..851714740 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,10 @@ +2009-11-14 Peter O'Gorman + + Only use preopen loader to load preopened archives + * libltdl/ltdl.c: Limit checking of .a to preopen loader. + * tests/lt_dlopen_a.at: Add test. + * Makefile.am: Add test. + 2009-05-05 Ralf Wildenhues libtoolize: ignore trailing junk on scriptversion line. @@ -8,7 +15,6 @@ Emacs to use UTC. Exposed by the `libtoolize config files serial update' test. - 2008-09-07 Gary V. Vaughan Fix typo in Makefile.maint. diff --git a/Makefile.am b/Makefile.am index 1417e8428..2d33f731c 100644 --- a/Makefile.am +++ b/Makefile.am @@ -454,6 +454,7 @@ TESTSUITE_AT = tests/testsuite.at \ tests/am-subdir.at \ tests/lt_dlexit.at \ tests/lt_dladvise.at \ + tests/lt_dlopen_a.at \ tests/ltdl-api.at \ tests/need_lib_prefix.at \ tests/standalone.at \ diff --git a/libltdl/ltdl.c b/libltdl/ltdl.c index 6e19599f8..1ce4479b0 100644 --- a/libltdl/ltdl.c +++ b/libltdl/ltdl.c @@ -529,7 +529,8 @@ find_module (lt_dlhandle *handle, const char *dir, const char *libdir, /* Try to open the old library first; if it was dlpreopened, we want the preopened version of it, even if a dlopenable module is available. */ - if (old_name && tryall_dlopen (handle, old_name, advise, 0) == 0) + if (old_name && tryall_dlopen (handle, old_name, + advise, lt_dlloader_find ("lt_preopen") ) == 0) { return 0; } diff --git a/tests/lt_dlopen_a.at b/tests/lt_dlopen_a.at new file mode 100644 index 000000000..8ab5c50d8 --- /dev/null +++ b/tests/lt_dlopen_a.at @@ -0,0 +1,97 @@ +# lt_dlopen_a.at -- test libltdl functionality -*- Autotest -*- +# +# Copyright (C) 2009 Free Software Foundation, Inc. +# This file is part of GNU Libtool. +# +# GNU Libtool is free software; you can redistribute it and/or +# modify it under the terms of the GNU General Public License as +# published by the Free Software Foundation; either version 2 of +# the License, or (at your option) any later version. +# +# GNU Libtool is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with GNU Libtool; see the file COPYING. If not, a copy +# can be downloaded from http://www.gnu.org/licenses/gpl.html, +# or obtained by writing to the Free Software Foundation, Inc., +# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +#### + +AT_SETUP([lt_dlopen archive]) +AT_KEYWORDS([libltdl lt_dlopen_a]) + +AT_DATA([main.c], +[[#include +#include + +/* This dlopen() in the main executable should override any dlopen()s in + shared libraries etc. + + If that is not the case (or the platform does not use dlopen()) then this + test should exit 77, causing the test to SKIP. +*/ +static int retcde = 77; + +void * dlopen(const char *path, int mode) { + if (!(strcmp(path,"plugin.a") && strcmp(path,"plugin.lib"))) + { + fprintf(stderr,"Tried to open archive %s\n",path); + retcde = 1; + } + else + { + fprintf(stderr,"Opening ... %s\n", path); + if (retcde == 77) retcde = 0; + } + return NULL; +} + +int +main (int argc, char* argv[]) +{ + int err = 0; + lt_dlhandle plugin_handle; + + lt_dlinit (); + plugin_handle = lt_dlopenext (argv[1]); + lt_dlexit (); + return retcde; +} +]]) + +AT_DATA([plugin.c], +[[ +int i = 1; +]]) + +: ${LTDLINCL="-I$abs_top_srcdir/libltdl"} +: ${LIBLTDL="$abs_builddir/../libltdl/libltdlc.la"} + +CPPFLAGS="$LTDLINCL $CPPFLAGS" +inst=`pwd`/inst +libdir=$inst/lib +bindir=$inst/bin + +AT_CHECK([$CC $CPPFLAGS $CFLAGS -c main.c || exit 77],[],[ignore],[ignore]) +AT_CHECK([$LIBTOOL --mode=compile $CC $CPPFLAGS $CFLAGS -c plugin.c || exit 77], + [], [ignore], [ignore]) +AT_CHECK([$LIBTOOL --mode=link $CC $CFLAGS $LDFLAGS -o plugin.la -rpath ]dnl + [$libdir -module -no-undefined -avoid-version plugin.lo || exit 77], + [], [ignore], [ignore]) + +AT_CHECK([$LIBTOOL --mode=link $CC $CFLAGS $LDFLAGS -o main$EXEEXT ]dnl + [main.$OBJEXT -dlopen plugin.la $LIBLTDL || exit 77], + [], [ignore], [ignore]) + +mkdir -p $libdir +mkdir -p $bindir + +AT_CHECK([$LIBTOOL --mode=install cp plugin.la $libdir],[], [ignore], [ignore]) +AT_CHECK([$LIBTOOL --mode=install cp main$EXEEXT $bindir],[], [ignore], [ignore]) +AT_CHECK([test -f $libdir/plugin.a || exit 77]) +LT_AT_EXEC_CHECK([$bindir/main $libdir/plugin.la], [], [ignore], [ignore]) + +AT_CLEANUP