+2009-10-22 Paul Pluzhnikov <ppluzhnikov@google.com>
+
+ PR gdb/10819
+ * dwarf2-frame.c (find_cie): Don't call bsearch on empty cie_table.
+ * objfiles.c (find_pc_section): Likewise.
+ (update_section_map): Don't allocate empty table.
+
2009-10-19 Don Lee <don.lee@sunplusct.com>
* score-tdep.c: Delete some simulator dependent codes.
{
struct dwarf2_cie **p_cie;
+ /* The C standard (ISO/IEC 9899:TC2) requires the BASE argument to
+ bsearch be non-NULL. */
+ if (cie_table->entries == NULL)
+ {
+ gdb_assert (cie_table->num_entries == 0);
+ return NULL;
+ }
+
p_cie = bsearch (&cie_pointer, cie_table->entries, cie_table->num_entries,
sizeof (cie_table->entries[0]), bsearch_cie_cmp);
if (p_cie != NULL)
if (insert_section_p (objfile->obfd, s->the_bfd_section))
alloc_size += 1;
+ /* This happens on detach/attach (e.g. in gdb.base/attach.exp). */
+ if (alloc_size == 0)
+ {
+ *pmap = NULL;
+ *pmap_size = 0;
+ return;
+ }
+
map = xmalloc (alloc_size * sizeof (*map));
i = 0;
objfiles_changed_p = 0;
}
+ /* The C standard (ISO/IEC 9899:TC2) requires the BASE argument to
+ bsearch be non-NULL. */
+ if (sections == NULL)
+ {
+ gdb_assert (num_sections == 0);
+ return NULL;
+ }
+
sp = (struct obj_section **) bsearch (&pc, sections, num_sections,
sizeof (*sections), bsearch_cmp);
if (sp != NULL)