]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
libgo: use -Wc,-shared-libgcc on Solaris
authorIan Lance Taylor <iant@golang.org>
Fri, 19 Dec 2025 19:17:48 +0000 (11:17 -0800)
committerIan Lance Taylor <iant@golang.org>
Fri, 19 Dec 2025 23:23:49 +0000 (15:23 -0800)
Patch from Rainer Orth.

For GCC PR go/64900

Reviewed-on: https://go-review.googlesource.com/c/gofrontend/+/731482

gcc/go/gofrontend/MERGE
libgo/Makefile.am
libgo/Makefile.in
libgo/configure
libgo/configure.ac
libgo/testsuite/Makefile.in

index c1abe89afb7eee7554e30200f2d41fc461f6d420..4520e543784a3ba4c162487aad4538c53e7b092f 100644 (file)
@@ -1,4 +1,4 @@
-ace35ffba59c926d401a6d3f918bd3c85f48c8fd
+6e421340885c87c4987f27be4a16b7bedb86faaa
 
 The first line of this file holds the git revision number of the last
 merge done from the gofrontend repository.
index 3eccadbac67bfd62962a4c86db04ba2df297ea5b..d139d7818ec4248bf58833f1c5208fd28873bc47 100644 (file)
@@ -837,7 +837,8 @@ libgo_go_objs = \
        $(golangorg_x_sys_cpu_gccgo_x86_lo)
 
 libgo_ldflags = \
-       -version-info $(libtool_VERSION) $(PTHREAD_CFLAGS) $(AM_LDFLAGS)
+       -version-info $(libtool_VERSION) $(PTHREAD_CFLAGS) $(AM_LDFLAGS) \
+       $(OSLDFLAGS)
 
 libgo_libadd = \
        $(libgo_go_objs) ../libbacktrace/libbacktrace.la \
index 0a2b7ee55301015cb4a2e968ef8b34a40e0b6475..6e194d084dae1a6a59bfadf803d0db796cfc8041 100644 (file)
@@ -453,6 +453,7 @@ OBJCOPY = @OBJCOPY@
 OBJDUMP = @OBJDUMP@
 OBJEXT = @OBJEXT@
 OSCFLAGS = @OSCFLAGS@
+OSLDFLAGS = @OSLDFLAGS@
 OTOOL = @OTOOL@
 OTOOL64 = @OTOOL64@
 PACKAGE = @PACKAGE@
@@ -972,7 +973,8 @@ libgo_go_objs = \
        $(golangorg_x_sys_cpu_gccgo_x86_lo)
 
 libgo_ldflags = \
-       -version-info $(libtool_VERSION) $(PTHREAD_CFLAGS) $(AM_LDFLAGS)
+       -version-info $(libtool_VERSION) $(PTHREAD_CFLAGS) $(AM_LDFLAGS) \
+       $(OSLDFLAGS)
 
 libgo_libadd = \
        $(libgo_go_objs) ../libbacktrace/libbacktrace.la \
index bba3c7aa7804fca651503063932d074ad83933f3..fa290d43ba21eb166fe0520a905cb65107fa262c 100755 (executable)
@@ -658,6 +658,7 @@ GO_SPLIT_STACK
 USING_SPLIT_STACK_FALSE
 USING_SPLIT_STACK_TRUE
 SPLIT_STACK
+OSLDFLAGS
 HWCAP_CFLAGS
 OSCFLAGS
 GO_SYSCALL_OS_ARCH_FILE
@@ -11547,7 +11548,7 @@ else
   lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
   lt_status=$lt_dlunknown
   cat > conftest.$ac_ext <<_LT_EOF
-#line 11550 "configure"
+#line 11551 "configure"
 #include "confdefs.h"
 
 #if HAVE_DLFCN_H
@@ -11653,7 +11654,7 @@ else
   lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
   lt_status=$lt_dlunknown
   cat > conftest.$ac_ext <<_LT_EOF
-#line 11656 "configure"
+#line 11657 "configure"
 #include "confdefs.h"
 
 #if HAVE_DLFCN_H
@@ -14457,6 +14458,15 @@ $as_echo "$ac_hwcap_flags" >&6; }
 
 
 
+case "$target" in
+    *86*-*-solaris2.*)
+       # Link with -shared-libgcc on Solaris 11+/x86 as a workaround for
+       # PR go/64900.
+       OSLDFLAGS="-Wc,-shared-libgcc"
+       ;;
+esac
+
+
 { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether -fsplit-stack is supported" >&5
 $as_echo_n "checking whether -fsplit-stack is supported... " >&6; }
 if ${libgo_cv_c_split_stack_supported+:} false; then :
index f8fe5f2ed98f207fd2cdf1c9f264bdf622cb5127..0004819d967dc7be99b2f4541f66cdb09fb6cd9b 100644 (file)
@@ -442,6 +442,15 @@ AC_SUBST(OSCFLAGS)
 dnl Check if assembler supports disabling hardware capability support.
 GCC_CHECK_ASSEMBLER_HWCAP
 
+case "$target" in
+    *86*-*-solaris2.*)
+       # Link with -shared-libgcc on Solaris 11+/x86 as a workaround for
+       # PR go/64900.
+       OSLDFLAGS="-Wc,-shared-libgcc"
+       ;;
+esac
+AC_SUBST(OSLDFLAGS)
+
 dnl Use -fsplit-stack when compiling C code if available.
 AC_CACHE_CHECK([whether -fsplit-stack is supported],
 [libgo_cv_c_split_stack_supported],
index 7c2e2e62fcf3b339dc32ae083abf5d848d13c295..0b5e7263dcc344fd86856409b0b1fbcfb8e9e253 100644 (file)
@@ -202,6 +202,7 @@ OBJCOPY = @OBJCOPY@
 OBJDUMP = @OBJDUMP@
 OBJEXT = @OBJEXT@
 OSCFLAGS = @OSCFLAGS@
+OSLDFLAGS = @OSLDFLAGS@
 OTOOL = @OTOOL@
 OTOOL64 = @OTOOL64@
 PACKAGE = @PACKAGE@