aboutsummaryrefslogtreecommitdiff
path: root/gas/config/obj-som.c
diff options
context:
space:
mode:
authorAlan Modra <amodra@gmail.com>2018-12-01 09:37:48 +1030
committerAlan Modra <amodra@gmail.com>2018-12-01 15:18:04 +1030
commit0acc7632bb09cce832a1b3756d31cc3fa93a724a (patch)
treed55c1680973037e5cc8ced249bcda4f9b33fa91e /gas/config/obj-som.c
parent35d1b0784a27fcd71daf1b058423010c9001f039 (diff)
downloadfsf-binutils-gdb-0acc7632bb09cce832a1b3756d31cc3fa93a724a.zip
fsf-binutils-gdb-0acc7632bb09cce832a1b3756d31cc3fa93a724a.tar.gz
fsf-binutils-gdb-0acc7632bb09cce832a1b3756d31cc3fa93a724a.tar.bz2
PR23938, should not free memory alloced in obstack by free()
This removes ineffectual and wrong code caching section names in gas/stabs.c. Code like seg = subseg_new (name, 0); ... if (seg->name == name) seg->name = xstrdup (name); with the idea of being able to unconditionally free "name" later no longer works. "name" is referenced by the section hash table as well as in the section->name field. It would be possible to use "bfd_rename_section (stdoutput, seg, xstrdup (name))", but instead I opted for a fairly straight-forward approach of adding extra parameters to two functions to indicate section name strings should be freed if possible. PR 23938 * read.h (get_stab_string_offset): Update prototype. * stabs.c (get_stab_string_offset): Add free_stabstr_secname parameter. Free stabstr_secname if unused as section name. Don't xstrdup name when used. (s_stab_generic): Remove forward declaration. Add stab_secname_obstack_end param. Reference notes obstack via macros. Delete cached_secname. Adjust get_stab_string_offset call. Free stab_secname if unused as section name. (s_stab): Adjust s_stab_generic call. (s_xstab): Likewise. Delete saved_secname and saved_strsecname. * config/obj-elf.c (obj_elf_init_stab_section): Adjust get_stab_string_offset call. * config/obj-coff.c (obj_coff_init_stab_section): Likewise. * config/obj-som.c (obj_som_init_stab_section): Likewise. * testsuite/gas/all/pr23938.s: New test. * testsuite/gas/all/gas.exp: Run it.
Diffstat (limited to 'gas/config/obj-som.c')
-rw-r--r--gas/config/obj-som.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/gas/config/obj-som.c b/gas/config/obj-som.c
index 3f2e27b..491bef8 100644
--- a/gas/config/obj-som.c
+++ b/gas/config/obj-som.c
@@ -243,7 +243,7 @@ obj_som_init_stab_section (segT seg)
p = frag_more (12);
memset (p, 0, 12);
file = as_where ((unsigned int *) NULL);
- stroff = get_stab_string_offset (file, "$GDB_STRINGS$");
+ stroff = get_stab_string_offset (file, "$GDB_STRINGS$", FALSE);
know (stroff == 1);
md_number_to_chars (p, stroff, 4);
seg_info (seg)->stabu.p = p;