]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
re PR target/6429 (libgcc_s problem on dual 32/64-bit arches)
authorJakub Jelinek <jakub@redhat.com>
Wed, 8 May 2002 23:18:39 +0000 (01:18 +0200)
committerJakub Jelinek <jakub@gcc.gnu.org>
Wed, 8 May 2002 23:18:39 +0000 (01:18 +0200)
PR target/6429
* Makefile.in (libgcc.mk): Pass SHLIB_SLIBDIR_SUFFIXES to mklibgcc.
* mklibgcc.in: If SHLIB_SLIBDIR_SUFFIXES is defined, put libgcc_s
shared libraries into multilib dirs, with SONAME libgcc_s.so.1 for
base multilibs.
* config/t-slibgcc-elf-ver (SHLIB_LINK): Adjust for the above.
* config/t-slibgcc-sld (SHLIB_LINK): Likewise.
* config/i386/t-linux64 (SHLIB_SLIBDIR_SUFFIXES): Define.
* config/sparc/t-linux64 (SHLIB_SLIBDIR_SUFFIXES): Define.
* config/sparc/t-sol2-64 (SHLIB_SLIBDIR_SUFFIXES): Define.

* lib/g77.exp (g77_link_flags): Append all multilib dirs containing
libgcc_s*.so.1 below gcc object dir to LD_LIBRARY_PATH.
* lib/g++.exp (g++_link_flags): Likewise.
* lib/objc.exp (objc_target_compile): Likewise.

* testsuite/lib/libstdc++-v3-dg.exp (libstdc++-v3-init): Append all
multilib dirs containing libgcc_s*.so.1 below gcc object dir to
LD_LIBRARY_PATH.

* testsuite/lib/libjava.exp (libjava_arguments): Append all
multilib dirs containing libgcc_s*.so.1 below gcc object dir to
LD_LIBRARY_PATH.

From-SVN: r53310

16 files changed:
gcc/ChangeLog
gcc/Makefile.in
gcc/config/i386/t-linux64
gcc/config/sparc/t-linux64
gcc/config/sparc/t-sol2-64
gcc/config/t-slibgcc-elf-ver
gcc/config/t-slibgcc-sld
gcc/mklibgcc.in
gcc/testsuite/ChangeLog
gcc/testsuite/lib/g++.exp
gcc/testsuite/lib/g77.exp
gcc/testsuite/lib/objc.exp
libjava/ChangeLog
libjava/testsuite/lib/libjava.exp
libstdc++-v3/ChangeLog
libstdc++-v3/testsuite/lib/libstdc++-v3-dg.exp

index 17ffeab8b3ad1b8c409c74480ed5d16eda468670..797b8226d03dbf3bcd7ab2508a7c0831703819e3 100644 (file)
@@ -1,3 +1,16 @@
+2002-05-09  Jakub Jelinek  <jakub@redhat.com>
+
+       PR target/6429
+       * Makefile.in (libgcc.mk): Pass SHLIB_SLIBDIR_SUFFIXES to mklibgcc.
+       * mklibgcc.in: If SHLIB_SLIBDIR_SUFFIXES is defined, put libgcc_s
+       shared libraries into multilib dirs, with SONAME libgcc_s.so.1 for
+       base multilibs.
+       * config/t-slibgcc-elf-ver (SHLIB_LINK): Adjust for the above.
+       * config/t-slibgcc-sld (SHLIB_LINK): Likewise.
+       * config/i386/t-linux64 (SHLIB_SLIBDIR_SUFFIXES): Define.
+       * config/sparc/t-linux64 (SHLIB_SLIBDIR_SUFFIXES): Define.
+       * config/sparc/t-sol2-64 (SHLIB_SLIBDIR_SUFFIXES): Define.
+
 2002-05-08  Mark Mitchell  <mark@codesourcery.com>
 
        PR c/6569.
index 687b4a76d4bda0962dec3c5fb0e9180c2a8e4da6..c3593415944eec5fb3305c13fba3f30b34a34ba3 100644 (file)
@@ -1002,6 +1002,7 @@ libgcc.mk: config.status Makefile mklibgcc $(LIB2ADD) $(LIB2ADD_ST) xgcc$(exeext
        SHLIB_MKMAP_OPTS='$(SHLIB_MKMAP_OPTS)' \
        SHLIB_MAPFILES='$(SHLIB_MAPFILES)' \
        SHLIB_NM_FLAGS='$(SHLIB_NM_FLAGS)' \
+       SHLIB_SLIBDIR_SUFFIXES='$(SHLIB_SLIBDIR_SUFFIXES)' \
        mkinstalldirs='$(SHELL) $(srcdir)/mkinstalldirs' \
          $(SHELL) mklibgcc > tmp-libgcc.mk
        mv tmp-libgcc.mk libgcc.mk
index 23e3918d7339e7ae8b7cd7dff6ce513c64051115..149452884f0bd04d9fd3203af974f25a9a0391f1 100644 (file)
@@ -9,3 +9,5 @@ LIBGCC = stmp-multilib
 INSTALL_LIBGCC = install-multilib
 
 EXTRA_MULTILIB_PARTS=crtbegin.o crtend.o crtbeginS.o crtendS.o crtbeginT.o
+
+SHLIB_SLIBDIR_SUFFIXES = 64:64 32:
index 4f552e07d1e8d93b89fc80f6245836269d79fb0c..d8dedc542bd76b27d26246010db1f40de97a4f80 100644 (file)
@@ -8,3 +8,5 @@ LIBGCC = stmp-multilib
 INSTALL_LIBGCC = install-multilib
 
 EXTRA_MULTILIB_PARTS=crtbegin.o crtend.o crtbeginS.o crtendS.o crtbeginT.o
+
+SHLIB_SLIBDIR_SUFFIXES = 64:64 32:
index 8d42c4453542c0400a5a16d2e6148367122e8b63..ef7dee7ecab2b4dea97b99b320dcb598b1c502cd 100644 (file)
@@ -6,3 +6,5 @@ LIBGCC = stmp-multilib
 INSTALL_LIBGCC = install-multilib
 
 EXTRA_MULTILIB_PARTS=crtbegin.o crtend.o gmon.o crt1.o crti.o crtn.o gcrt1.o
+
+SHLIB_SLIBDIR_SUFFIXES = sparcv9:/sparcv9 sparcv7:
index d6c89ff8acbdbcbbf0fc59a7f932cdeb0b0ce320..c02ff9d6b7c7acfd4f55596929ecfd34f5745cac 100644 (file)
@@ -2,22 +2,28 @@
 # with the GNU linker.
 
 SHLIB_EXT = .so
-SHLIB_NAME = @shlib_base_name@.so
-SHLIB_SONAME = @shlib_base_name@.so.1
+SHLIB_SOLINK = @shlib_base_name@.so
+SHLIB_SONAME = @shlib_so_name@.so.1
+SHLIB_NAME = @shlib_dir@@shlib_so_name@.so.1
 SHLIB_MAP = @shlib_map_file@
 SHLIB_OBJS = @shlib_objs@
+SHLIB_SLIBDIR_QUAL = @shlib_slibdir_qual@
 SHLIB_LC = -lc
 
 SHLIB_LINK = $(GCC_FOR_TARGET) $(LIBGCC2_CFLAGS) -shared -nodefaultlibs \
        -Wl,--soname=$(SHLIB_SONAME) \
        -Wl,--version-script=$(SHLIB_MAP) \
        -o $(SHLIB_NAME) @multilib_flags@ $(SHLIB_OBJS) $(SHLIB_LC) && \
-       rm -f $(SHLIB_SONAME) && \
-       $(LN_S) $(SHLIB_NAME) $(SHLIB_SONAME)
+       rm -f $(SHLIB_SOLINK) && \
+       $(LN_S) $(SHLIB_NAME) $(SHLIB_SOLINK)
 # $(slibdir) double quoted to protect it from expansion while building
 # libgcc.mk.  We want this delayed until actual install time.
-SHLIB_INSTALL = $(INSTALL_DATA) $(SHLIB_NAME) $$(slibdir)/$(SHLIB_SONAME); \
-       rm -f $$(slibdir)/$(SHLIB_NAME); \
-       $(LN_S) $(SHLIB_SONAME) $$(slibdir)/$(SHLIB_NAME)
+SHLIB_INSTALL = \
+       $$(SHELL) $$(srcdir)/mkinstalldirs $$(slibdir)$(SHLIB_SLIBDIR_QUAL); \
+       $(INSTALL_DATA) $(SHLIB_NAME) \
+         $$(slibdir)$(SHLIB_SLIBDIR_QUAL)/$(SHLIB_SONAME); \
+       rm -f $$(slibdir)$(SHLIB_SLIBDIR_QUAL)/$(SHLIB_SOLINK); \
+       $(LN_S) $(SHLIB_SONAME) \
+         $$(slibdir)$(SHLIB_SLIBDIR_QUAL)/$(SHLIB_SOLINK)
 SHLIB_MKMAP = $(srcdir)/mkmap-symver.awk
 SHLIB_MAPFILES = $(srcdir)/libgcc-std.ver
index 35f1bc15fd7384c3d977b7f4729db10002335f7a..c11a572196681a69e269b079bcb7aa1423b59e6e 100644 (file)
@@ -1,21 +1,27 @@
 # Build a shared libgcc library with the Solaris linker.
 
 SHLIB_EXT = .so
-SHLIB_NAME = @shlib_base_name@.so
-SHLIB_SONAME = @shlib_base_name@.so.1
+SHLIB_SOLINK = @shlib_base_name@.so
+SHLIB_SONAME = @shlib_so_name@.so.1
+SHLIB_NAME = @shlib_dir@@shlib_so_name@.so.1
 SHLIB_MAP = @shlib_map_file@
 SHLIB_OBJS = @shlib_objs@
+SHLIB_SLIBDIR_QUAL = @shlib_slibdir_qual@
 
 SHLIB_LINK = $(GCC_FOR_TARGET) $(LIBGCC2_CFLAGS) -shared -nodefaultlibs \
        -Wl,-h,$(SHLIB_SONAME) -Wl,-z,text -Wl,-z,defs \
        -Wl,-M,$(SHLIB_MAP) -o $(SHLIB_NAME) \
        @multilib_flags@ $(SHLIB_OBJS) -lc && \
-       rm -f $(SHLIB_SONAME) && \
-       $(LN_S) $(SHLIB_NAME) $(SHLIB_SONAME)
+       rm -f $(SHLIB_SOLINK) && \
+       $(LN_S) $(SHLIB_NAME) $(SHLIB_SOLINK)
 # $(slibdir) double quoted to protect it from expansion while building
 # libgcc.mk.  We want this delayed until actual install time.
-SHLIB_INSTALL = $(INSTALL_DATA) $(SHLIB_NAME) $$(slibdir)/$(SHLIB_SONAME); \
-       rm -f $$(slibdir)/$(SHLIB_NAME); \
-       $(LN_S) $(SHLIB_SONAME) $$(slibdir)/$(SHLIB_NAME)
+SHLIB_INSTALL = \
+       $$(SHELL) $$(srcdir)/mkinstalldirs $$(slibdir)$(SHLIB_SLIBDIR_QUAL); \
+       $(INSTALL_DATA) $(SHLIB_NAME) \
+         $$(slibdir)$(SHLIB_SLIBDIR_QUAL)/$(SHLIB_SONAME); \
+       rm -f $$(slibdir)$(SHLIB_SLIBDIR_QUAL)/$(SHLIB_SOLINK); \
+       $(LN_S) $(SHLIB_SONAME) \
+         $$(slibdir)$(SHLIB_SLIBDIR_QUAL)/$(SHLIB_SOLINK)
 SHLIB_MKMAP = $(srcdir)/mkmap-symver.awk
 SHLIB_MAPFILES = $(srcdir)/libgcc-std.ver
index 8018eca2f643a0a6d0fb0447c445de765be47370..911f2e03e8749e759fbb931f4eeae550b71f3bb9 100644 (file)
@@ -32,6 +32,7 @@
 # SHLIB_MAPFILES
 # SHLIB_NM_FLAGS
 # SHLIB_INSTALL
+# SHLIB_SLIBDIR_SUFFIXES
 
 # Make needs VPATH to be literal.
 echo 'srcdir = @srcdir@'
@@ -306,11 +307,31 @@ for ml in $MULTILIBS; do
     echo '     else true; fi;'
 
     if [ -z "$SHLIB_MULTILIB" ]; then
-      if [ "$dir" = "." ]; then
-       shlib_base_name="libgcc_s";
+      if [ "$dir" = . ]; then
+       shlib_base_name=libgcc_s
       else
        shlib_base_name=libgcc_s_`echo $dir | sed s,/,_,g`
       fi
+      shlib_so_name="$shlib_base_name"
+      shlib_dir=
+      if [ -n "$SHLIB_SLIBDIR_SUFFIXES" ]; then
+       if [ "$dir" != . ]; then
+         shlib_dir="$dir"/
+         for suffix_pair in $SHLIB_SLIBDIR_SUFFIXES ; do
+           base_ml_dir=`echo ${suffix_pair} | sed -e 's/:.*$//' -e 's/=/$(EQ)/g'`
+           if [ "$dir" = "$base_ml_dir" ]; then
+             shlib_so_name=libgcc_s
+             break
+           else
+             canon_dir=`echo $dir | sed -n -e "s:$base_ml_dir/::p"`
+             if [ -n "$canon_dir" ]; then
+               shlib_so_name=libgcc_s_`echo $canon_dir | sed s,/,_,g`
+               break
+             fi
+           fi
+         done
+       fi
+      fi
       echo ""
       echo "${dir}/${shlib_base_name}${SHLIB_EXT}: $shlib_deps"
       echo "   $SHLIB_LINK" \
@@ -318,7 +339,9 @@ for ml in $MULTILIBS; do
               -e "s%@multilib_dir@%$dir%g" \
               -e "s%@shlib_objs@%$libgcc_sh_objs%g" \
               -e "s%@shlib_base_name@%$shlib_base_name%g" \
-              -e "s%@shlib_map_file@%$mapfile%g"
+              -e "s%@shlib_map_file@%$mapfile%g" \
+              -e "s%@shlib_so_name@%$shlib_so_name%g" \
+              -e "s%@shlib_dir@%$shlib_dir%g"
     elif [ "$SHLIB_MULTILIB" = "$dir" ]; then
       shlib_base_name="libgcc_s";
       echo ""
@@ -328,7 +351,9 @@ for ml in $MULTILIBS; do
               -e "s%@multilib_dir@%$dir%g" \
               -e "s%@shlib_objs@%$libgcc_sh_objs%g" \
               -e "s%@shlib_base_name@%$shlib_base_name%g" \
-              -e "s%@shlib_map_file@%$mapfile%g"
+              -e "s%@shlib_map_file@%$mapfile%g" \
+              -e "s%@shlib_so_name@%$shlib_base_name%g" \
+              -e "s%@shlib_dir@%%g"
     fi
   fi
 done
@@ -424,17 +449,60 @@ for ml in $MULTILIBS; do
     echo '     $(RANLIB_FOR_TARGET)' ${ldir}/libgcc_eh.a
 
     if [ -z "$SHLIB_MULTILIB" ]; then
-      if [ "$dir" = "." ]; then
-       shlib_base_name="libgcc_s";
+      if [ "$dir" = . ]; then
+       shlib_base_name=libgcc_s
       else
        shlib_base_name=libgcc_s_`echo $dir | sed s,/,_,g`
       fi
+      shlib_so_name="$shlib_base_name"
+      shlib_dir=
+      shlib_slibdir_qual=none
+      if [ -n "$SHLIB_SLIBDIR_SUFFIXES" ]; then
+       if [ "$dir" != . ]; then
+         shlib_dir="$dir"/
+         for suffix_pair in $SHLIB_SLIBDIR_SUFFIXES ; do
+           base_ml_dir=`echo ${suffix_pair} | sed -e 's/:.*$//' -e 's/=/$(EQ)/g'`
+           if [ "$dir" = "$base_ml_dir" ]; then
+             shlib_so_name=libgcc_s
+             shlib_slibdir_qual=`echo ${suffix_pair} | sed -e 's/^[^:]*://'`
+             break
+           else
+             canon_dir=`echo $dir | sed -n -e "s:$base_ml_dir/::p"`
+             if [ -n "$canon_dir" ]; then
+               shlib_so_name=libgcc_s_`echo $canon_dir | sed s,/,_,g`
+               shlib_slibdir_qual=`echo ${suffix_pair} | sed -e 's/^[^:]*://'`
+               break
+             fi
+           fi
+         done
+       fi
+       if [ "$shlib_slibdir_qual" = none ]; then
+         for suffix_pair in $SHLIB_SLIBDIR_SUFFIXES ; do
+           base_ml_dir=`echo ${suffix_pair} | sed -e 's/:.*$//' -e 's/=/$(EQ)/g'`
+           shlib_slibdir_qual=`echo ${suffix_pair} | sed -e 's/^[^:]*://'`
+           for ml2 in $MULTILIBS; do
+             dir2=`echo ${ml2} | sed -e 's/;.*$//' -e 's/=/$(EQ)/g'`
+             if [ "$base_ml_dir" = "$dir2" ]; then
+               shlib_slibdir_qual=
+               break
+             fi
+           done
+           if [ -n "$shlib_slibdir_qual" ]; then break; fi
+         done
+       fi
+      fi
       echo "   $SHLIB_INSTALL" \
-       | sed -e "s%@shlib_base_name@%$shlib_base_name%g"
+       | sed -e "s%@shlib_base_name@%$shlib_base_name%g" \
+             -e "s%@shlib_so_name@%$shlib_so_name%g" \
+             -e "s%@shlib_dir@%$shlib_dir%g" \
+             -e "s%@shlib_slibdir_qual@%$shlib_slibdir_qual%g"
     elif [ "$SHLIB_MULTILIB" = "$dir" ]; then
       shlib_base_name="libgcc_s";
       echo "   $SHLIB_INSTALL" \
-       | sed -e "s%@shlib_base_name@%$shlib_base_name%g"
+       | sed -e "s%@shlib_base_name@%$shlib_base_name%g" \
+             -e "s%@shlib_so_name@%$shlib_base_name%g" \
+             -e "s%@shlib_dir@%%g" \
+             -e "s%@shlib_slibdir_qual@%%g"
     fi
   fi
 done
index 57828875fe1986890ea0984f809da63267b0767a..63b9fe07eb10397ad386a43095cc8d4ffc0f0008 100644 (file)
@@ -1,3 +1,10 @@
+2002-05-09  Jakub Jelinek  <jakub@redhat.com>
+
+       * lib/g77.exp (g77_link_flags): Append all multilib dirs containing
+       libgcc_s*.so.1 below gcc object dir to LD_LIBRARY_PATH.
+       * lib/g++.exp (g++_link_flags): Likewise.
+       * lib/objc.exp (objc_target_compile): Likewise.
+
 2002-05-08  Mark Mitchell  <mark@codesourcery.com>
 
        PR c/6569
index a9a49e4e619ccfa33342c4f49c55bf0f44f4801f..4fb903eed66eb5ba68ab78a4b0bae4a6cd7ba7f6 100644 (file)
@@ -1,4 +1,5 @@
-# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 2000, 2001 Free Software Foundation, Inc.
+# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 2000, 2001, 2002
+# Free Software Foundation, Inc.
 
 # This program is free software; you can redistribute it and/or modify
 # it under the terms of the GNU General Public License as published by
@@ -108,6 +109,7 @@ proc g++_link_flags { paths } {
     global rootme
     global srcdir
     global ld_library_path
+    global GXX_UNDER_TEST
 
     set gccpath ${paths}
     set libio_dir ""
@@ -137,6 +139,20 @@ proc g++_link_flags { paths } {
           append flags "-L${gccpath}/librx "
       }
       append ld_library_path ":${rootme}"
+      set compiler [lindex $GXX_UNDER_TEST 0]
+      if { [is_remote host] == 0 && [which $compiler] != 0 } {
+       foreach i "[exec $compiler --print-multi-lib]" {
+         set mldir ""
+         regexp -- "\[a-z0-9=/\.-\]*;" $i mldir
+         set mldir [string trimright $mldir "\;@"]
+         if { "$mldir" == "." } {
+           continue
+         }
+         if { [llength [glob -nocomplain ${rootme}/${mldir}/libgcc_s*.so.*]] == 1 } {
+           append ld_library_path ":${rootme}/${mldir}"
+         }
+       }
+      }
     } else {
       global tool_root_dir;
 
index 8ad51e9b56b15499a396f4527e9ec52b6c93950b..42780c227c90dc14d06ee6036258a7720b5dc669 100644 (file)
@@ -75,6 +75,7 @@ proc g77_link_flags { paths } {
     global rootme
     global srcdir
     global ld_library_path
+    global G77_UNDER_TEST
 
     set gccpath ${paths}
     set libio_dir ""
@@ -93,6 +94,20 @@ proc g77_link_flags { paths } {
           append flags "-L${gccpath}/libiberty "
       }
       append ld_library_path ":${rootme}"
+      set compiler [lindex $G77_UNDER_TEST 0]
+      if { [is_remote host] == 0 && [which $compiler] != 0 } {
+       foreach i "[exec $compiler --print-multi-lib]" {
+         set mldir ""
+         regexp -- "\[a-z0-9=/\.-\]*;" $i mldir
+         set mldir [string trimright $mldir "\;@"]
+         if { "$mldir" == "." } {
+           continue
+         }
+         if { [llength [glob -nocomplain ${rootme}/${mldir}/libgcc_s*.so.*]] == 1 } {
+           append ld_library_path ":${rootme}/${mldir}"
+         }
+       }
+      }
     }
 
     # On IRIX 6, we have to set variables akin to LD_LIBRARY_PATH, but
index d82442c4382f9dbc89d93814203d6726ef25d871..a1431a116ec03756ced5704b89add0b095322e05 100644 (file)
@@ -1,4 +1,4 @@
-# Copyright (C) 1992, 1993, 1994, 1996, 1997, 2000, 2001
+# Copyright (C) 1992, 1993, 1994, 1996, 1997, 2000, 2001, 2002
 # Free Software Foundation, Inc.
 
 # This program is free software; you can redistribute it and/or modify
@@ -85,12 +85,14 @@ proc objc_version { } {
 set objc_initialized 0
 
 proc objc_init { args } {
+    global rootme
     global tmpdir
     global libdir
     global gluefile wrap_flags
     global objc_initialized
     global OBJC_UNDER_TEST
     global TOOL_EXECUTABLE
+    global objc_libgcc_s_path
 
     if { $objc_initialized == 1 } { return; }
 
@@ -115,6 +117,22 @@ proc objc_init { args } {
            unset gluefile
        }
     }
+
+    set objc_libgcc_s_path "${rootme}"
+    set compiler [lindex $OBJC_UNDER_TEST 0]
+    if { [is_remote host] == 0 && [which $compiler] != 0 } {
+       foreach i "[exec $compiler --print-multi-lib]" {
+           set mldir ""
+           regexp -- "\[a-z0-9=/\.-\]*;" $i mldir
+           set mldir [string trimright $mldir "\;@"]
+           if { "$mldir" == "." } {
+               continue
+           }
+           if { [llength [glob -nocomplain ${rootme}/${mldir}/libgcc_s*.so.*]] == 1 } {
+               append objc_libgcc_s_path ":${rootme}/${mldir}"
+           }
+       }
+    }
 }
 
 proc objc_target_compile { source dest type options } {
@@ -124,8 +142,9 @@ proc objc_target_compile { source dest type options } {
     global OBJC_UNDER_TEST
     global TOOL_OPTIONS
     global ld_library_path
+    global objc_libgcc_s_path
 
-    set ld_library_path ".:${rootme}"
+    set ld_library_path ".:${objc_libgcc_s_path}"
     lappend options "libs=-lobjc"
 
     if { [target_info needs_status_wrapper]!="" && [info exists gluefile] } {
index 5f2ff4bc5addbb4ff13d44c1bd91d58a2f02ec87..1b7f15d52db723eaa9cc184298878292d7ab7915 100644 (file)
@@ -1,3 +1,9 @@
+2002-05-09  Jakub Jelinek  <jakub@redhat.com>
+
+       * testsuite/lib/libjava.exp (libjava_arguments): Append all
+       multilib dirs containing libgcc_s*.so.1 below gcc object dir to
+       LD_LIBRARY_PATH.
+
 2002-05-08  Alexandre Oliva  <aoliva@redhat.com>
 
        * configure.in (ORIGINAL_LD_FOR_MULTILIBS): Preserve LD at
index c932374625944962bb04d7c911013c4f0b89bab1..4bbd0f0965d06cd4577541f1ffce5c423d591b3a 100644 (file)
@@ -112,6 +112,8 @@ proc libjava_init { args } {
     global TOOL_EXECUTABLE
     global original_ld_library_path
     global env objdir
+    global tool_root_dir
+    global libjava_libgcc_s_path
 
     if { $libjava_initialized == 1 } { return; }
 
@@ -164,6 +166,29 @@ proc libjava_init { args } {
        }
     }
 
+    # Finally, add the gcc build directory so that we can find the
+    # shared libgcc.  This, like much of dejagnu, is hideous.
+    set libjava_libgcc_s_path {}
+    set gccdir [lookfor_file $tool_root_dir gcc/libgcc_s.so]
+    if {$gccdir != ""} {
+       set gccdir [file dirname $gccdir]
+       lappend libjava_libgcc_s_path $gccdir
+       set compiler ${gccdir}/xgcc
+       if { [is_remote host] == 0 && [which $compiler] != 0 } {
+           foreach i "[exec $compiler --print-multi-lib]" {
+               set mldir ""
+               regexp -- "\[a-z0-9=/\.-\]*;" $i mldir
+               set mldir [string trimright $mldir "\;@"]
+               if { "$mldir" == "." } {
+                   continue
+               }
+               if { [llength [glob -nocomplain ${gccdir}/${mldir}/libgcc_s*.so.*]] == 1 } {
+                   lappend libjava_libgcc_s_path "${gccdir}/${mldir}"
+               }
+           }
+       }
+    }
+
     set libjava_initialized 1
 }
 
@@ -240,6 +265,7 @@ proc libjava_arguments {{mode compile}} {
     global runtests
     global env
     global tool_root_dir
+    global libjava_libgcc_s_path
 
     if [info exists LIBJAVA] {
        set libjava $LIBJAVA;
@@ -289,13 +315,7 @@ proc libjava_arguments {{mode compile}} {
        }
     }
 
-    # Finally, add the gcc build directory so that we can find the
-    # shared libgcc.  This, like much of dejagnu, is hideous.
-    set gccdir [lookfor_file $tool_root_dir gcc/libgcc_s.so]
-    if {$gccdir != ""} {
-       lappend lpath [file dirname $gccdir]
-    }
-
+    set lpath [concat $lpath $libjava_libgcc_s_path]
     set ld_library_path [join $lpath :]
 
     # That's enough to make things work for the normal case.
index 91e279793df49aba0ad5b728db74b0da0a0faa65..19658c1308df1468ea3ab211760ec6e9a89ccb82 100644 (file)
@@ -1,3 +1,9 @@
+2002-05-09  Jakub Jelinek  <jakub@redhat.com>
+
+       * testsuite/lib/libstdc++-v3-dg.exp (libstdc++-v3-init): Append all
+       multilib dirs containing libgcc_s*.so.1 below gcc object dir to
+       LD_LIBRARY_PATH.
+
 2002-05-08  Alexandre Oliva  <aoliva@redhat.com>
 
        * configure.in (ORIGINAL_LD_FOR_MULTILIBS): Preserve LD at
index b3f6b7fc885ff328726e7acd9e4f4d35a741f7d5..77bdce8c745e37af6baa5d61c67db0f44e8c03fd 100644 (file)
@@ -67,6 +67,20 @@ proc libstdc++-v3-init { args } {
 
     set ld_library_path "."
     append ld_library_path ":${gccdir}"
+    set compiler ${gccdir}/g++
+    if { [is_remote host] == 0 && [which $compiler] != 0 } {
+      foreach i "[exec $compiler --print-multi-lib]" {
+       set mldir ""
+       regexp -- "\[a-z0-9=/\.-\]*;" $i mldir
+       set mldir [string trimright $mldir "\;@"]
+       if { "$mldir" == "." } {
+         continue
+       }
+       if { [llength [glob -nocomplain ${gccdir}/${mldir}/libgcc_s*.so.*]] == 1 } {
+         append ld_library_path ":${gccdir}/${mldir}"
+       }
+      }
+    }
     append ld_library_path ":${blddir}/src/.libs"
 
     # On IRIX 6, we have to set variables akin to LD_LIBRARY_PATH, but