diff options
author | Alan Modra <amodra@gmail.com> | 2019-04-29 09:17:05 +0930 |
---|---|---|
committer | Alan Modra <amodra@gmail.com> | 2019-04-30 22:04:32 +0930 |
commit | 8107ddcea1da07f1c4e902c17f045684beb78079 (patch) | |
tree | 0af9356c84cbd77dc78706b422a11ff51a8da3d8 /binutils | |
parent | 06ddcada14d90c4da28f9585801aaae48304d8ea (diff) | |
download | binutils-8107ddcea1da07f1c4e902c17f045684beb78079.zip binutils-8107ddcea1da07f1c4e902c17f045684beb78079.tar.gz binutils-8107ddcea1da07f1c4e902c17f045684beb78079.tar.bz2 |
Work around gcc9 warning bug
* wrstabs.c (stab_start_class_type): Add assert to work around
gcc9 warning. Tidy.
Diffstat (limited to 'binutils')
-rw-r--r-- | binutils/ChangeLog | 5 | ||||
-rw-r--r-- | binutils/wrstabs.c | 22 |
2 files changed, 14 insertions, 13 deletions
diff --git a/binutils/ChangeLog b/binutils/ChangeLog index 8fbc761..364fddb 100644 --- a/binutils/ChangeLog +++ b/binutils/ChangeLog @@ -1,3 +1,8 @@ +2019-04-30 Alan Modra <amodra@gmail.com> + + * wrstabs.c (stab_start_class_type): Add assert to work around + gcc9 warning. Tidy. + 2019-04-24 Nick Clifton <nickc@redhat.com> * objcopy.c (strip_main): Do not enable note merging by default if diff --git a/binutils/wrstabs.c b/binutils/wrstabs.c index 3d1839f..3e941dc 100644 --- a/binutils/wrstabs.c +++ b/binutils/wrstabs.c @@ -1440,18 +1440,15 @@ stab_end_struct_type (void *p) /* Start outputting a class. */ static bfd_boolean -stab_start_class_type (void *p, const char *tag, unsigned int id, bfd_boolean structp, unsigned int size, bfd_boolean vptr, bfd_boolean ownvptr) +stab_start_class_type (void *p, const char *tag, unsigned int id, + bfd_boolean structp, unsigned int size, + bfd_boolean vptr, bfd_boolean ownvptr) { struct stab_write_handle *info = (struct stab_write_handle *) p; - bfd_boolean definition; - char *vstring; + bfd_boolean definition = FALSE; + char *vstring = NULL; - if (! vptr || ownvptr) - { - definition = FALSE; - vstring = NULL; - } - else + if (vptr && !ownvptr) { definition = info->type_stack->definition; vstring = stab_pop_type (info); @@ -1472,17 +1469,16 @@ stab_start_class_type (void *p, const char *tag, unsigned int id, bfd_boolean st } else { + assert (vstring); vtable = (char *) xmalloc (strlen (vstring) + 3); sprintf (vtable, "~%%%s", vstring); free (vstring); + if (definition) + info->type_stack->definition = TRUE; } - info->type_stack->vtable = vtable; } - if (definition) - info->type_stack->definition = TRUE; - return TRUE; } |