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:
parent
b5242b2845
commit
5f7c2d20b5
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
Loading…
Reference in New Issue
Block a user