libtool-patches
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[patch #9313] _LT_SYS_DYNAMIC_LINKER: Untagged variable values may be in


From: Michael Haubenwallner
Subject: [patch #9313] _LT_SYS_DYNAMIC_LINKER: Untagged variable values may be inconsistent across tags.
Date: Thu, 20 Apr 2017 10:25:06 -0400 (EDT)
User-agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Firefox/52.0

URL:
  <http://savannah.gnu.org/patch/?9313>

                 Summary: _LT_SYS_DYNAMIC_LINKER: Untagged variable values may
be inconsistent across tags.
                 Project: GNU Libtool
            Submitted by: haubi
            Submitted on: Thu 20 Apr 2017 04:25:04 PM CEST
                Category: None
                Priority: 5 - Normal
                  Status: None
                 Privacy: Public
             Assigned to: None
        Originator Email: 
             Open/Closed: Open
         Discussion Lock: Any

    _______________________________________________________

Details:

Although _LT_SYS_DYNAMIC_LINKER does support the [TAG] argument, almost all of
the variables it does set are untagged variables.

While untagged variables are (expected to be) defined using the "C" language
compiler, their values apply for each other language (=tag) as well.

As _LT_SYS_DYNAMIC_LINKER is run for multiple tags, these untagged variables
are redefined again for no good reason. While this is not a problem by itself,
it is a needless slowdown for the configure script.

However, a problem does arise when their values change with different language
compilers, for example when using MSVC cl.exe as the C compiler (with Cygwin
as the POSIX system):

*./configure CC=cl.exe CXX='cl.exe /TP'* results in libname_spec='ltdl' for
the empty tag, which is incorporated into LTDLOPEN, causing libltdl/ltdl.c to
refer lt_ltdl__LTX_preloaded_symbols.

But subsequent checks for F77 and FC run _LT_SYS_DYNAMIC_LINKER with
$cc_basename != "cl.exe", causing libname_spec='libltdl', which finally ends
up in the libtool script, causing lt_libltdl__LTX_preloaded_symbols to be
generated.
Note "libltdl" != "ltdl" in the symbol name.

The error message seen here is:

   Creating library libltdl/.libs/libltdl.dll.lib and object
libltdl/.libs/libltdl.dll.exp
libltdl_libltdl_la-ltdl.obj : error LNK2019: unresolved external symbol
_lt_ltdl_LTX_preloaded_symbols referenced in function _lt_dlinit
libltdl/.libs/libltdl-7.dll : fatal error LNK1120: 1 unresolved externals
make[2]: *** [Makefile:1139: libltdl/libltdl.la] Error 2





    _______________________________________________________

Reply to this item at:

  <http://savannah.gnu.org/patch/?9313>

_______________________________________________
  Message sent via/by Savannah
  http://savannah.gnu.org/




reply via email to

[Prev in Thread] Current Thread [Next in Thread]