From: Mark Wielaard Date: Mon, 27 Aug 2012 12:30:05 +0000 (+0200) Subject: readelf.c (register_info): Handle loc == NULL. X-Git-Tag: elfutils-0.155~2 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=e89c500fbbd7a54912b06fce0729367b94b52a50;p=thirdparty%2Felfutils.git readelf.c (register_info): Handle loc == NULL. register_info is called by print_cfa_program with loc being NULL. Signed-off-by: Mark Wielaard --- diff --git a/src/ChangeLog b/src/ChangeLog index d80f844fe..72804bd9a 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,3 +1,7 @@ +2012-08-27 Mark Wielaard + + * readelf.c (register_info): Handle loc == NULL. + 2012-08-22 Jeff Kenton * elflint.c (valid_e_machine): Add EM_TILEGX and EM_TILEPRO. diff --git a/src/readelf.c b/src/readelf.c index dc496695b..4ff8ebbd9 100644 --- a/src/readelf.c +++ b/src/readelf.c @@ -4305,9 +4305,12 @@ register_info (Ebl *ebl, unsigned int regno, const Ebl_Register_Location *loc, bits ?: &ignore, type ?: &ignore); if (n <= 0) { - snprintf (name, REGNAMESZ, "reg%u", loc->regno); + if (loc != NULL) + snprintf (name, REGNAMESZ, "reg%u", loc->regno); + else + snprintf (name, REGNAMESZ, "??? 0x%x", regno); if (bits != NULL) - *bits = loc->bits; + *bits = loc != NULL ? loc->bits : 0; if (type != NULL) *type = DW_ATE_unsigned; set = "??? unrecognized"; @@ -4315,7 +4318,7 @@ register_info (Ebl *ebl, unsigned int regno, const Ebl_Register_Location *loc, else { if (bits != NULL && *bits <= 0) - *bits = loc->bits; + *bits = loc != NULL ? loc->bits : 0; if (type != NULL && *type == DW_ATE_void) *type = DW_ATE_unsigned;