aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJan Beulich <jbeulich@suse.com>2016-07-01 14:23:24 +0000
committerJan Beulich <jbeulich@gcc.gnu.org>2016-07-01 14:23:24 +0000
commit059541fd113a360000b08753e355898cdeeaa431 (patch)
treed6335a7ae0fa08c73f02972395d93d140ba010c9 /gcc
parent51433308bb18319f173f75339e1ac1eb2fe24e80 (diff)
downloadgcc-059541fd113a360000b08753e355898cdeeaa431.zip
gcc-059541fd113a360000b08753e355898cdeeaa431.tar.gz
gcc-059541fd113a360000b08753e355898cdeeaa431.tar.bz2
check initializer to be zero in .bss-like sections
Just like gas, which has recently learned to reject such initializers, gcc shouldn't accept such either. gcc/ 2016-07-01 Jan Beulich <jbeulich@suse.com> * varasm.c (get_variable_section): Validate initializer in named .bss-like sections. gcc/testsuite/ 2016-07-01 Jan Beulich <jbeulich@suse.com> * gcc.dg/bss.c: New. From-SVN: r237913
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/testsuite/ChangeLog4
-rw-r--r--gcc/testsuite/gcc.dg/bss.c8
-rw-r--r--gcc/varasm.c13
4 files changed, 29 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 3295534..4020a4e 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2016-07-01 Jan Beulich <jbeulich@suse.com>
+
+ * varasm.c (get_variable_section): Validate initializer in
+ named .bss-like sections.
+
2016-07-01 Kelvin Nilsen <kelvin@gcc.gnu.org>
* config/rs6000/altivec.md (*altivec_vpermr_<mode>_internal):
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 1eca9b2..382c172 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,7 @@
+2016-07-01 Jan Beulich <jbeulich@suse.com>
+
+ * gcc.dg/bss.c: New.
+
2016-07-01 Peter Bergner <bergner@vnet.ibm.com>
PR target/71698
diff --git a/gcc/testsuite/gcc.dg/bss.c b/gcc/testsuite/gcc.dg/bss.c
new file mode 100644
index 0000000..af8d0c6
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/bss.c
@@ -0,0 +1,8 @@
+/* Test non-zero initializers in .bss-like sections get properly refused. */
+/* { dg-do compile } */
+/* { dg-require-named-sections "" } */
+
+int __attribute__((section(".bss.local"))) x = 1; /* { dg-error "" "zero init" } */
+int *__attribute__((section(".bss.local"))) px = &x; /* { dg-error "" "zero init" } */
+int __attribute__((section(".bss.local"))) y = 0;
+int *__attribute__((section(".bss.local"))) py = (void*)0;
diff --git a/gcc/varasm.c b/gcc/varasm.c
index de8bcd6..6a8fb81 100644
--- a/gcc/varasm.c
+++ b/gcc/varasm.c
@@ -1150,7 +1150,18 @@ get_variable_section (tree decl, bool prefer_noswitch_p)
resolve_unique_section (decl, reloc, flag_data_sections);
if (IN_NAMED_SECTION (decl))
- return get_named_section (decl, NULL, reloc);
+ {
+ section *sect = get_named_section (decl, NULL, reloc);
+
+ if ((sect->common.flags & SECTION_BSS) && !bss_initializer_p (decl))
+ {
+ error_at (DECL_SOURCE_LOCATION (decl),
+ "only zero initializers are allowed in section %qs",
+ sect->named.name);
+ DECL_INITIAL (decl) = error_mark_node;
+ }
+ return sect;
+ }
if (ADDR_SPACE_GENERIC_P (as)
&& !DECL_THREAD_LOCAL_P (decl)