Although we are already in trouble when realloc fails don't make it
worse. When realloc fails we have to free the original pointer we
wanted to extend to not cause an even bigger memory leak.
* tools/debugedit.c (read_abbrev): Free original t after realloc
fails.
Signed-off-by: Mark Wielaard <mark@klomp.org>
{
if (t->nattr == size)
{
+ struct abbrev_tag *orig_t = t;
size += 10;
t = realloc (t, sizeof (*t) + size * sizeof (struct abbrev_attr));
if (t == NULL)
- goto no_memory;
+ {
+ free (orig_t);
+ goto no_memory;
+ }
}
form = read_uleb128 (ptr);
if (form == 2