]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
go: Update usage of TARGET_AIX to TARGET_AIX_OS
authorPaul E. Murphy <murphyp@linux.ibm.com>
Thu, 22 Jun 2023 22:53:46 +0000 (17:53 -0500)
committerPeter Bergner <bergner@linux.ibm.com>
Thu, 29 Jun 2023 03:03:50 +0000 (22:03 -0500)
TARGET_AIX is defined to a non-zero value on linux and maybe other
powerpc64le targets.  This leads to unexpected behavior such as
dropping the .go_export section when linking a shared library
on linux/powerpc64le.

Instead, use TARGET_AIX_OS to toggle AIX specific behavior.

Fixes golang/go#60798.

2023-06-22  Paul E. Murphy  <murphyp@linux.ibm.com>

gcc/go/
* go-backend.c [TARGET_AIX]: Rename and update usage to TARGET_AIX_OS.
* go-lang.c: Likewise.

(cherry picked from commit b76cd1ec361712e1ac9ca5e0246da24ea2b78916)

gcc/go/go-backend.c
gcc/go/go-lang.c

index 5d1aaf0e63a813b639bf63eec49333f2716356d2..d94468fd52dff46941940cf077de0ba4e5c17ec4 100644 (file)
@@ -45,8 +45,8 @@ along with GCC; see the file COPYING3.  If not see
 #define GO_EXPORT_SECTION_NAME ".go_export"
 #endif
 
-#ifndef TARGET_AIX
-#define TARGET_AIX 0
+#ifndef TARGET_AIX_OS
+#define TARGET_AIX_OS 0
 #endif
 
 /* This file holds all the cases where the Go frontend needs
@@ -107,7 +107,7 @@ go_write_export_data (const char *bytes, unsigned int size)
     {
       gcc_assert (targetm_common.have_named_sections);
       sec = get_section (GO_EXPORT_SECTION_NAME,
-                        TARGET_AIX ? SECTION_EXCLUDE : SECTION_DEBUG,
+                        TARGET_AIX_OS ? SECTION_EXCLUDE : SECTION_DEBUG,
                         NULL);
     }
 
index 387694e4f56d610aeda03e52059fc3aab83402df..92c65df4624d6726c7eb61d0affa270e030b32c3 100644 (file)
@@ -39,8 +39,8 @@ along with GCC; see the file COPYING3.  If not see
 #include "go-c.h"
 #include "go-gcc.h"
 
-#ifndef TARGET_AIX
-#define TARGET_AIX 0
+#ifndef TARGET_AIX_OS
+#define TARGET_AIX_OS 0
 #endif
 
 /* Language-dependent contents of a type.  */
@@ -117,7 +117,7 @@ go_langhook_init (void)
   args.compiling_runtime = go_compiling_runtime;
   args.debug_escape_level = go_debug_escape_level;
   args.debug_escape_hash = go_debug_escape_hash;
-  args.nil_check_size_threshold = TARGET_AIX ? -1 : 4096;
+  args.nil_check_size_threshold = TARGET_AIX_OS ? -1 : 4096;
   args.debug_optimization = go_debug_optimization;
   args.linemap = go_get_linemap();
   args.backend = go_get_backend();