From: Mark Wielaard Date: Mon, 20 Jan 2014 12:49:48 +0000 (+0100) Subject: addr2line: handle_address initialize scopes to NULL. X-Git-Tag: elfutils-0.159~47 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=247f85869852e5f0fc461c4c9827d1347e75204a;p=thirdparty%2Felfutils.git addr2line: handle_address initialize scopes to NULL. dwarf_getscopes returns the number of scope DIEs containing a PC address. It returns -1 for errors or 0 if no scopes match PC. If dwarf_getscopes returned 0, then scopes will not be allocated and handle_address might free the uninitialized scopes pointer. Make sure it always has a defined value. Signed-off-by: Mark Wielaard --- diff --git a/src/ChangeLog b/src/ChangeLog index 99b115645..57be0bb34 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,3 +1,7 @@ +2014-01-20 Mark Wielaard + + * addr2line.c (handle_address): Initialize scopes to NULL. + 2014-01-17 Roland McGrath * strip.c (handle_elf): Check for bogus values in sh_link, sh_info, diff --git a/src/addr2line.c b/src/addr2line.c index 0541fb686..50fc2b38c 100644 --- a/src/addr2line.c +++ b/src/addr2line.c @@ -642,7 +642,7 @@ handle_address (const char *string, Dwfl *dwfl) Dwarf_Addr bias = 0; Dwarf_Die *cudie = dwfl_module_addrdie (mod, addr, &bias); - Dwarf_Die *scopes; + Dwarf_Die *scopes = NULL; int nscopes = dwarf_getscopes (cudie, addr - bias, &scopes); if (nscopes < 0) return 1;