summaryrefslogtreecommitdiff
path: root/gcc/varasm.c
diff options
context:
space:
mode:
authorrobertl <robertl@138bc75d-0d04-0410-961f-82ee72b054a4>2001-10-08 22:41:55 +0000
committerrobertl <robertl@138bc75d-0d04-0410-961f-82ee72b054a4>2001-10-08 22:41:55 +0000
commit5cdb6d3147d1aa9c70ee30e474b7b2b785e071b2 (patch)
tree855a56530e6a6db9b761b28846fc3a61c596e605 /gcc/varasm.c
parentebed3b99a35afe8bd311b4be73d0103d67c5a97f (diff)
downloadgcc-5cdb6d3147d1aa9c70ee30e474b7b2b785e071b2.tar.gz
* varasm.c (struct in_named_entry): Add declared.
(named_section_first_declaration): New function. (default_elf_asm_named_section): Use it. * output.h (named_section_first_declaration): New. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@46108 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/varasm.c')
-rw-r--r--gcc/varasm.c32
1 files changed, 32 insertions, 0 deletions
diff --git a/gcc/varasm.c b/gcc/varasm.c
index d2a59d8e43e..cc79f206432 100644
--- a/gcc/varasm.c
+++ b/gcc/varasm.c
@@ -216,6 +216,7 @@ struct in_named_entry
{
const char *name;
unsigned int flags;
+ bool declared;
};
static htab_t in_named_htab;
@@ -340,6 +341,31 @@ get_named_section_flags (section)
return slot ? (*slot)->flags : 0;
}
+/* Returns true if the section has been declared before. Sets internal
+ flag on this section in in_named_hash so subsequent calls on this
+ section will return false. */
+
+bool
+named_section_first_declaration (name)
+ const char *name;
+{
+ struct in_named_entry **slot;
+
+ slot = (struct in_named_entry**)
+ htab_find_slot_with_hash (in_named_htab, name,
+ htab_hash_string (name), NO_INSERT);
+ if (! (*slot)->declared)
+ {
+ (*slot)->declared = true;
+ return true;
+ }
+ else
+ {
+ return false;
+ }
+}
+
+
/* Record FLAGS for SECTION. If SECTION was previously recorded with a
different set of flags, return false. */
@@ -5205,6 +5231,12 @@ default_elf_asm_named_section (name, flags)
char flagchars[10], *f = flagchars;
const char *type;
+ if (! named_section_first_declaration (name))
+ {
+ fprintf (asm_out_file, "\t.section\t%s\n", name);
+ return;
+ }
+
if (!(flags & SECTION_DEBUG))
*f++ = 'a';
if (flags & SECTION_WRITE)