diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index aaa7c8cbac0487a30f90596986553becf05a91ad..58ed17dffb2002f7af8e15fb87b108a222c2797d 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2005-09-30  Geoffrey Keating  <geoffk@apple.com>
+
+	* config/t-slibgcc-darwin (libgcc_s_%.dylib): Use --print-multi-lib
+	to work out which multilibs are actually being built.
+
 2005-09-30  Kazu Hirata  <kazu@codesourcery.com>
 
 	* tree-vect-transform.c, config/ms1/ms1.md,
diff --git a/gcc/config/t-slibgcc-darwin b/gcc/config/t-slibgcc-darwin
index 6650bb54b8985f010c3fcbbe8da5cb4eb71345d4..3a2fc185c41c5db2f9e6e25d978100bcd9cee188 100644
--- a/gcc/config/t-slibgcc-darwin
+++ b/gcc/config/t-slibgcc-darwin
@@ -43,10 +43,11 @@ ASM_HIDDEN_OP = .private_extern
 # contain no code, just a list of exported symbols.
 # The actual use of the libraries is controlled by REAL_LIBGCC_SPEC.
 # 
-# This assumes only one level of multilibs.  It also assumes each multilib
-# corresponds to a different architecture.
+# This assumes each multilib corresponds to a different architecture.
 libgcc_s.%.dylib : $(SHLIB_VERPFX).%.ver libgcc.a
-	for mlib in '' $(MULTILIB_DIRNAMES:%=_%) ; do \
+	MLIBS=`$(GCC_FOR_TARGET) --print-multi-lib \
+		| sed -e 's/;.*$$//' -e '/^\.$$/d' -e 's/^/_/'` ; \
+	for mlib in '' $$MLIBS ; do \
 	  $(STRIP_FOR_TARGET) -o $(@)_T$${mlib} \
 	    -s $(SHLIB_VERPFX).$(*).ver -c -u \
 	    libgcc_s$${mlib}.$(SHLIB_SOVERSION)$(SHLIB_EXT) || exit 1 ; \
@@ -54,7 +55,9 @@ libgcc_s.%.dylib : $(SHLIB_VERPFX).%.ver libgcc.a
 	$(LIPO_FOR_TARGET) -output $@ -create $(@)_T*
 	# When builting multilibbed target libraries, all the required
 	# libraries are expected to exist in the multilib directory.
-	for mlib in $(MULTILIB_DIRNAMES) ; do \
+	MLIBS=`$(GCC_FOR_TARGET) --print-multi-lib \
+		| sed -e 's/;.*$$//' -e '/^\.$$/d'` ; \
+	for mlib in $$MLIBS ; do \
 	  ln -s ../$@ $${mlib}/$@ || exit 1 ; \
 	done
 	rm $(@)_T*