diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 30c4078a9e..b98297cf10 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,13 @@ +2011-05-11 Jan Kratochvil + + Make addrs->SECTINDEX always defined. + * symfile.c (relative_addr_info_to_section_offsets): Check for + SECTINDEX -1, not for zero ADDR. + (addrs_section_compar): Remove checking for invalid SECTINDEX. + (addr_info_make_relative): Set SECTINDEX to -1 for unmatched entries. + * symfile.h (struct section_addr_info) : Update the comment + on its validity. + 2011-05-10 Doug Evans * linux-thread-db.c: Whitespace cleanup. diff --git a/gdb/symfile.c b/gdb/symfile.c index cec687092c..4689e0e310 100644 --- a/gdb/symfile.c +++ b/gdb/symfile.c @@ -527,7 +527,7 @@ relative_addr_info_to_section_offsets (struct section_offsets *section_offsets, struct other_sections *osp; osp = &addrs->other[i]; - if (osp->addr == 0) + if (osp->sectindex == -1) continue; /* Record all sections in offsets. */ @@ -568,10 +568,7 @@ addrs_section_compar (const void *ap, const void *bp) if (retval) return retval; - /* SECTINDEX is undefined iff ADDR is zero. */ - a_idx = a->addr == 0 ? 0 : a->sectindex; - b_idx = b->addr == 0 ? 0 : b->sectindex; - return a_idx - b_idx; + return a->sectindex - b->sectindex; } /* Provide sorted array of pointers to sections of ADDRS. The array is @@ -734,8 +731,7 @@ addr_info_make_relative (struct section_addr_info *addrs, bfd *abfd) bfd_get_filename (abfd)); addrs->other[i].addr = 0; - - /* SECTINDEX is invalid if ADDR is zero. */ + addrs->other[i].sectindex = -1; } } diff --git a/gdb/symfile.h b/gdb/symfile.h index 4dfd4d36c1..35444756fb 100644 --- a/gdb/symfile.h +++ b/gdb/symfile.h @@ -86,7 +86,7 @@ struct section_addr_info CORE_ADDR addr; char *name; - /* SECTINDEX must be valid for associated BFD if ADDR is not zero. */ + /* SECTINDEX must be valid for associated BFD or set to -1. */ int sectindex; } other[1]; };