From: Mark Wielaard Date: Sun, 17 Jun 2018 22:23:23 +0000 (+0200) Subject: libdw: aggregate_size check NULL result from get_type. X-Git-Tag: elfutils-0.173~12 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=9d7577842f9a8580552105507139c611af34e52f;p=thirdparty%2Felfutils.git libdw: aggregate_size check NULL result from get_type. aggregate_size can be called recursively with the result of get_type. get_type can return NULL when dwarf_peel_type fails. Found by afl-fuzz. dwarf_aggregate_size when called directly doesn't need a NULL check because it calls and checks the result of dwarf_peel_type directly. Signed-off-by: Mark Wielaard --- diff --git a/libdw/ChangeLog b/libdw/ChangeLog index bed63794f..1e41e72ae 100644 --- a/libdw/ChangeLog +++ b/libdw/ChangeLog @@ -1,3 +1,7 @@ +2018-06-18 Mark Wielaard + + * dwarf_aggregate_size.c (aggregate_size): Check die is not NULL. + 2018-06-17 Luiz Angelo Daros de Luca * dwarf_getsrclines.c (read_srclines): Intialize filelist early. diff --git a/libdw/dwarf_aggregate_size.c b/libdw/dwarf_aggregate_size.c index 6e501857b..d20db71a5 100644 --- a/libdw/dwarf_aggregate_size.c +++ b/libdw/dwarf_aggregate_size.c @@ -171,6 +171,9 @@ aggregate_size (Dwarf_Die *die, Dwarf_Word *size, Dwarf_Die *type_mem) { Dwarf_Attribute attr_mem; + if (die == NULL) + return -1; + if (INTUSE(dwarf_attr_integrate) (die, DW_AT_byte_size, &attr_mem) != NULL) return INTUSE(dwarf_formudata) (&attr_mem, size);