libabigail/src
Dodji Seketeli 5a8c000a87 Bug 19355 - Libabigail slow on r300_dri.so
Profiling abidw --abidiff r300_dri.so, with a r30_dri.so that was run
through dwz shows that a great deal of the time is spent in trying to
get the logical parent of a DIE which has been imported.

To do that, we need to walk the translation unit DIEs again to know
where the DIE we are looking at has been imported.  And doing that
walking again and again, following the accessors of the DIE data
structure from elfutils takes time.

This patch reduces that time by constructing a "trace" of where units
have been imported.  So that looking for the logical parent of a given
DIE doesn't involve walking the DIE tree itself, but rather, walking
the trace, which is a vector.  This proves to be much faster.

In practice, the overall time spent is now less than 12 minutes.  It
was more than 50 minutes before.

	* src/abg-dwarf-reader.cc (struct imported_unit_point): Define new
	type.
	(operator<(const imported_unit_point&, const
	imported_unit_point&)): Define less-than operator for new
	imported_unit_point& type.
	(imported_unit_points_type, tu_die_imported_unit_points_map_type):
	New typedefs.
	(find_lower_bound_in_imported_unit_points): Define new static function.
	(read_context::tu_die_imported_unit_points_map_): New data member.
	(read_context::tu_die_imported_unit_points_map): New getter.
	(die_die_attribute): Define new overload.
	(build_die_parent_relations_under): Take imported_unit_points_type
	output parameter and populate it along the way. Remove the
	overload that takes a read_context as a parameter.
	(build_primary_die_parent_relations_under)
	(build_alternate_die_parent_relations_under): Remove.
	(build_die_parent_maps): Pass an instance of
	imported_unit_points_type to build_die_parent_relations_under.
	(find_import_unit_point_between_dies): Rename one overload of
	find_last_import_unit_point_before_die into this.  Adjust to make
	it find the import point between two offsets.
	(find_import_unit_point_before_die): Rename the other overload of
	find_last_import_unit_point_before_die into this. Adjust to use
	find_import_unit_point_between_dies.
	(get_parent_die): Adjust to use find_import_unit_point_before_die.

Signed-off-by: Dodji Seketeli <dodji@redhat.com>
2016-01-04 19:58:02 +01:00
..
abg-comp-filter.cc Filter out harmless diagnostics glitches due to some ODR violation 2015-12-08 14:14:09 +01:00
abg-comparison.cc Add the option of printing the file, line and column information about a type being reported. 2015-12-15 12:32:55 +01:00
abg-config.cc Add --version option to several libabigail tools 2015-11-16 12:54:10 +01:00
abg-corpus.cc Style adjustment in abg-corpus.cc 2015-10-06 13:32:13 +02:00
abg-diff-utils.cc Update copyright years 2015-01-07 17:52:10 +01:00
abg-dwarf-reader.cc Bug 19355 - Libabigail slow on r300_dri.so 2016-01-04 19:58:02 +01:00
abg-hash.cc Misc style fixes 2015-09-21 14:49:29 +02:00
abg-ini.cc Support source_location_not_in and source_location_not_regexp suppressions 2015-09-16 20:54:40 +02:00
abg-ir.cc Support two different variables having the same underlying symbol 2016-01-04 19:58:02 +01:00
abg-libxml-utils.cc Update copyright years 2015-01-07 17:52:10 +01:00
abg-libzip-utils.cc Update copyright years 2015-01-07 17:52:10 +01:00
abg-reader.cc Avoid adding the same base class twice 2016-01-04 19:58:02 +01:00
abg-tools-utils.cc Bug 19139 - DWARF reader doesn't handle garbage in function names 2015-11-05 16:40:22 +01:00
abg-traverse.cc Update copyright years 2015-01-07 17:52:10 +01:00
abg-viz-common.cc Update copyright years 2015-01-07 17:52:10 +01:00
abg-viz-dot.cc Update copyright years 2015-01-07 17:52:10 +01:00
abg-viz-svg.cc Update copyright years 2015-01-07 17:52:10 +01:00
abg-writer.cc Bug 19126 - abidw segv on a dwz compressed version of r300_dri.so 2015-12-10 16:47:18 +01:00
Makefile.am Expose a new libabigail::tools_utils namespace 2015-01-08 12:28:14 +01:00