public inbox for gdb-prs@sourceware.org
help / color / mirror / Atom feed
From: "ssbssa at sourceware dot org" <sourceware-bugzilla@sourceware.org>
To: gdb-prs@sourceware.org
Subject: [Bug gdb/13498] save-index makes gdb slow with dwarf4
Date: Sun, 31 Dec 2023 13:08:39 +0000	[thread overview]
Message-ID: <bug-13498-4717-J6UqcCRoLD@http.sourceware.org/bugzilla/> (raw)
In-Reply-To: <bug-13498-4717@http.sourceware.org/bugzilla/>

https://sourceware.org/bugzilla/show_bug.cgi?id=13498

Hannes Domani <ssbssa at sourceware dot org> changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
                 CC|                            |ssbssa at sourceware dot org

--- Comment #12 from Hannes Domani <ssbssa at sourceware dot org> ---
(In reply to Sourceware Commits from comment #11)
> CVSROOT:	/cvs/src
> Module name:	src
> Changes by:	devans@sourceware.org	2012-07-10 20:28:34
> 
> Modified files:
> 	gdb            : ChangeLog dwarf2read.c 
> 
> Log message:
> 	PR gdb/13498
> 	* dwarf2read.c (dwarf2_per_objfile): New members n_type_unit_groups,
> 	all_type_unit_groups, type_unit_groups, tu_stats.
> 	(dwarf2_per_cu_data): Move "imported_symtabs" into new union "s".
> 	All uses updated.  Add type_unit_group to union "s".
> 	(type_unit_group): New struct.
> 	(IS_TYPE_UNIT_GROUP): New macro.
> 	(abbrev_table): Delete unused member "section".
> 	(dw2_do_instantiate_symtab): Early exit if type_unit_group.
> 	(dw2_get_cu): Assert not used with type_unit_group.
> 	(dw2_get_primary_cu): New function.
> 	(dw2_build_type_unit_groups_reader): New function.
> 	(dw2_build_type_unit_groups): New function.
> 	(dw2_get_file_names): Assert not called on type units.
> 	(dw2_map_symtabs_matching_filename): Call dw2_build_type_unit_groups.
> 	Redo loop to iterate over type unit groups instead of type units.
> 	(dw2_expand_symtabs_matching, dw2_map_symbol_filenames): Ditto.
> 	(read_abbrev_offset): New function.
> 	(init_cutu_and_read_dies): New arg "abbrev_table".  All callers
> 	updated.
> 	(create_partial_symtab): New function.
> 	(process_psymtab_comp_unit_reader): Assert not used with type units.
> 	Call create_partial_symtab.
> 	(process_psymtab_type_unit): Delete.
> 	(hash_type_unit_group, eq_type_unit_group): New functions.
> 	(allocate_type_unit_groups_table): New function.
> 	(NO_STMT_LIST_TYPE_UNIT_PSYMTAB): New macro.
> 	(NO_STMT_LIST_TYPE_UNIT_PSYMTAB_SIZE): New macro.
> 	(create_type_unit_group, get_type_unit_group): New functions.
> 	(tu_abbrev_offset): New struct.
> 	(sort_tu_by_abbrev_offset): New function.
> 	(add_type_unit_group_to_table): New function.
> 	(build_type_unit_groups): New function.
> 	(build_type_psymtabs_reader): New function.
> 	(build_type_psymtab_dependencies): New function.
> 	(build_type_psymtabs): Rewrite.
> 	(scan_partial_symbols): Flag an error if a DW_TAG_imported_unit
> 	is seen in a type unit.
> 	(process_queue): Move symtab expansion debugging printfs here.
> 	Call process_full_type_unit for type units.
> 	(compute_symtab_includes): Assert not called for type units.
> 	(process_cu_includes): Don't call compute_symtab_includes for
> 	type units.
> 	(process_full_type_unit): New function.
> 	(process_imported_unit_die): Flag an error if called for type units.
> 	(handle_DW_AT_stmt_list): Delete arg "want_line_info".  All callers
> 	updated.  Assert not called for type units.
> 	(read_file_scope): Call dwarf2_start_symtab.
> 	(setup_type_unit_groups): New function.
> 	(read_type_unit_scope): Rewrite.
> 	(abbrev_table_read_table): Initialize abbrev_table->offset.
> 	(abbrev_table_free_cleanup): New function.
> 	(dwarf2_start_symtab): New function.
> 	(load_full_type_unit): Assert not called for type unit groups.
> 
> Patches:
> http://sourceware.org/cgi-bin/cvsweb.cgi/src/gdb/ChangeLog.
> diff?cvsroot=src&r1=1.14457&r2=1.14458
> http://sourceware.org/cgi-bin/cvsweb.cgi/src/gdb/dwarf2read.c.
> diff?cvsroot=src&r1=1.683&r2=1.684

Did this coommit fix the issue, and can it be closed?

-- 
You are receiving this mail because:
You are on the CC list for the bug.

  parent reply	other threads:[~2023-12-31 13:08 UTC|newest]

Thread overview: 17+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2011-12-14 17:21 [Bug gdb/13498] New: " l.lunak at suse dot cz
2011-12-14 23:28 ` [Bug gdb/13498] " l.lunak at suse dot cz
2011-12-15 15:55 ` l.lunak at suse dot cz
2012-02-15 12:12 ` lionel at mamane dot lu
2012-02-16 11:00 ` mjw at redhat dot com
2012-02-17 21:48 ` tromey at redhat dot com
2012-02-17 21:52 ` tromey at redhat dot com
2012-02-20 13:51 ` l.lunak at suse dot cz
2012-02-20 19:51 ` tromey at redhat dot com
2012-02-20 19:55 ` tromey at redhat dot com
2012-02-20 20:57 ` cvs-commit at gcc dot gnu.org
2012-02-21  6:32 ` dje at google dot com
2012-02-21 18:17 ` l.lunak at suse dot cz
2012-07-08 19:35 ` dje at google dot com
2012-07-10 20:29 ` cvs-commit at gcc dot gnu.org
2023-12-31 13:08 ` ssbssa at sourceware dot org [this message]
2023-12-31 16:42 ` tromey at sourceware dot org

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=bug-13498-4717-J6UqcCRoLD@http.sourceware.org/bugzilla/ \
    --to=sourceware-bugzilla@sourceware.org \
    --cc=gdb-prs@sourceware.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).