get_type_abbrev_from_form is lax in not limiting data for a uleb to
the current CU, because DW_FORM_ref_addr allows access to other CU's
data. This can lead to an assertion fail when skipping or reading
attributes in get_type_signedness.
* dwarf.c (get_type_abbrev_from_form): Limit uleb data to map end
for ref_addr, cu_end otherwise.
*map_return = NULL;
}
- READ_ULEB (abbrev_number, data, section->start + section->size);
+ if (form == DW_FORM_ref_addr)
+ cu_end = section->start + map->end;
+
+ READ_ULEB (abbrev_number, data, cu_end);
for (entry = map->list->first_abbrev; entry != NULL; entry = entry->next)
if (entry->number == abbrev_number)