aix: revert TLS common change

GCC uses TLS common for both public common / BSS and local common / BSS.
This patch reverts to use .comm directive to allocate TLS
common / BSS.  This also changes the priority of section selection
to use BSS before data section.

gcc/ChangeLog:

	* config/rs6000/rs6000.c (rs6000_xcoff_select_section): Select
	TLS BSS before TLS data.
	* config/rs6000/xcoff.h (ASM_OUTPUT_TLS_COMMON): Use .comm.

gcc/testsuite/ChangeLog:

	* g++.dg/gomp/tls-5.C: Expect tbss failure on AIX.
This commit is contained in:
David Edelsohn 2021-04-07 21:34:02 -04:00
parent b5242b2845
commit 5f7c2d20b5
3 changed files with 9 additions and 9 deletions

View File

@ -21285,14 +21285,14 @@ rs6000_xcoff_select_section (tree decl, int reloc,
#if HAVE_AS_TLS #if HAVE_AS_TLS
if (TREE_CODE (decl) == VAR_DECL && DECL_THREAD_LOCAL_P (decl)) if (TREE_CODE (decl) == VAR_DECL && DECL_THREAD_LOCAL_P (decl))
{ {
if (TREE_PUBLIC (decl)) if (bss_initializer_p (decl))
return tls_data_section;
else if (bss_initializer_p (decl))
{ {
/* Convert to COMMON to emit in BSS. */ /* Convert to COMMON to emit in BSS. */
DECL_COMMON (decl) = 1; DECL_COMMON (decl) = 1;
return tls_comm_section; return tls_comm_section;
} }
else if (TREE_PUBLIC (decl))
return tls_data_section;
else else
return tls_private_data_section; return tls_private_data_section;
} }

View File

@ -255,11 +255,11 @@
} while (0) } while (0)
#ifdef HAVE_AS_TLS #ifdef HAVE_AS_TLS
#define ASM_OUTPUT_TLS_COMMON(FILE, DECL, NAME, SIZE) \ #define ASM_OUTPUT_TLS_COMMON(FILE, DECL, NAME, SIZE) \
do { fputs (LOCAL_COMMON_ASM_OP, (FILE)); \ do { fputs (COMMON_ASM_OP, (FILE)); \
fprintf ((FILE), "%s," HOST_WIDE_INT_PRINT_UNSIGNED",%s[UL],3\n", \ RS6000_OUTPUT_BASENAME ((FILE), (NAME)); \
(*targetm.strip_name_encoding) (NAME), (SIZE), \ fprintf ((FILE), "[UL]," HOST_WIDE_INT_PRINT_UNSIGNED"\n", \
(*targetm.strip_name_encoding) (NAME)); \ (SIZE)); \
} while (0) } while (0)
#endif #endif

View File

@ -1,7 +1,7 @@
// The reference temp should be TLS, not normal data. // The reference temp should be TLS, not normal data.
// { dg-require-effective-target c++11 } // { dg-require-effective-target c++11 }
// { dg-final { scan-assembler-not "\\.data" { target tls_native xfail powerpc-*-aix* } } } // { dg-final { scan-assembler-not "\\.data" { target tls_native xfail powerpc-*-aix* } } }
// { dg-final { scan-assembler-symbol-section {^_?ir$} {^\.tbss|\[TL\]} { target tls_native } } } // { dg-final { scan-assembler-symbol-section {^_?ir$} {^\.tbss} { target tls_native xfail powerpc-*-aix* } } }
// { dg-final { scan-assembler-symbol-section {^_?_ZGR2ir_$} {^\.tdata|\[TL\]} { target tls_native } } } // { dg-final { scan-assembler-symbol-section {^_?_ZGR2ir_$} {^\.tdata|\[TL\]} { target tls_native } } }
extern int&& ir; extern int&& ir;