]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
PR target/53372: Don't ignore section attribute with address-space.
authorGeorg-Johann Lay <avr@gjlay.de>
Fri, 17 Nov 2023 11:51:16 +0000 (12:51 +0100)
committerGeorg-Johann Lay <avr@gjlay.de>
Fri, 17 Nov 2023 11:54:25 +0000 (12:54 +0100)
gcc/
PR target/53372
* config/avr/avr.cc (avr_asm_named_section) [AVR_SECTION_PROGMEM]:
Only return some .progmem*.data section if the user did not
specify a section attribute.
(avr_section_type_flags) [avr_progmem_p]: Unset SECTION_NOTYPE
in returned section flags.

gcc/testsuite/
PR target/53372
* gcc.target/avr/pr53372-1.c: New test.
* gcc.target/avr/pr53372-2.c: New test.

gcc/config/avr/avr.cc
gcc/testsuite/gcc.target/avr/pr53372-1.c [new file with mode: 0644]
gcc/testsuite/gcc.target/avr/pr53372-2.c [new file with mode: 0644]

index 5e0217de36fc9f58ced8680118b74cfd95cfe84e..c3e0995dfc3b008524cda7de26f0c86bbaf8dcfa 100644 (file)
@@ -10873,7 +10873,12 @@ avr_asm_init_sections (void)
 static void
 avr_asm_named_section (const char *name, unsigned int flags, tree decl)
 {
-  if (flags & AVR_SECTION_PROGMEM)
+  if (flags & AVR_SECTION_PROGMEM
+      // Only use section .progmem*.data if there is no attribute section.
+      && ! (decl
+           && DECL_SECTION_NAME (decl)
+           && symtab_node::get (decl)
+           && ! symtab_node::get (decl)->implicit_section))
     {
       addr_space_t as = (flags & AVR_SECTION_PROGMEM) / SECTION_MACH_DEP;
       const char *old_prefix = ".rodata";
@@ -10942,6 +10947,7 @@ avr_section_type_flags (tree decl, const char *name, int reloc)
       flags |= as * SECTION_MACH_DEP;
       flags &= ~SECTION_WRITE;
       flags &= ~SECTION_BSS;
+      flags &= ~SECTION_NOTYPE;
     }
 
   return flags;
diff --git a/gcc/testsuite/gcc.target/avr/pr53372-1.c b/gcc/testsuite/gcc.target/avr/pr53372-1.c
new file mode 100644 (file)
index 0000000..7d3f193
--- /dev/null
@@ -0,0 +1,10 @@
+/* { dg-do compile { target { ! avr_tiny } } } */
+/* { dg-options "-std=gnu99" } */
+
+__attribute__((__section__("fffsection")))
+const __flash char fff = 123;
+
+const __flash char ppp = 124;
+
+/* { dg-final { scan-assembler ".section       fffsection,\"a\",@progbits" } } */
+/* { dg-final { scan-assembler ".section       .progmem.data,\"a\",@progbits" } } */
diff --git a/gcc/testsuite/gcc.target/avr/pr53372-2.c b/gcc/testsuite/gcc.target/avr/pr53372-2.c
new file mode 100644 (file)
index 0000000..79ef2b7
--- /dev/null
@@ -0,0 +1,10 @@
+/* { dg-do compile { target { ! avr_tiny } } } */
+/* { dg-options "-std=gnu99 -fdata-sections" } */
+
+__attribute__((__section__("fffsection")))
+const __flash char fff = 123;
+
+const __flash char ppp = 124;
+
+/* { dg-final { scan-assembler ".section       fffsection,\"a\",@progbits" } } */
+/* { dg-final { scan-assembler ".section       .progmem.data.ppp,\"a\",@progbits" } } */