From patchwork Fri Oct 25 19:29:55 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Simon Marchi (Code Review)" X-Patchwork-Id: 35348 Received: (qmail 62834 invoked by alias); 25 Oct 2019 19:30:03 -0000 Mailing-List: contact gdb-patches-help@sourceware.org; run by ezmlm Precedence: bulk List-Id: List-Unsubscribe: List-Subscribe: List-Archive: List-Post: List-Help: , Sender: gdb-patches-owner@sourceware.org Delivered-To: mailing list gdb-patches@sourceware.org Received: (qmail 62778 invoked by uid 89); 25 Oct 2019 19:30:02 -0000 Authentication-Results: sourceware.org; auth=none X-Spam-SWARE-Status: No, score=-25.4 required=5.0 tests=BAYES_00, GIT_PATCH_0, GIT_PATCH_1, GIT_PATCH_2, GIT_PATCH_3, KAM_STOCKGEN autolearn=ham version=3.3.1 spammy=*linkage_name X-HELO: mx1.osci.io Received: from polly.osci.io (HELO mx1.osci.io) (8.43.85.229) by sourceware.org (qpsmtpd/0.93/v0.84-503-g423c35a) with ESMTP; Fri, 25 Oct 2019 19:30:00 +0000 Received: by mx1.osci.io (Postfix, from userid 994) id 2D6DC21143; Fri, 25 Oct 2019 15:29:58 -0400 (EDT) Received: from gnutoolchain-gerrit.osci.io (gnutoolchain-gerrit.osci.io [IPv6:2620:52:3:1:5054:ff:fe06:16ca]) by mx1.osci.io (Postfix) with ESMTP id 8641220E95; Fri, 25 Oct 2019 15:29:55 -0400 (EDT) Received: from localhost (localhost [127.0.0.1]) by gnutoolchain-gerrit.osci.io (Postfix) with ESMTP id 6553D204C9; Fri, 25 Oct 2019 15:29:55 -0400 (EDT) X-Gerrit-PatchSet: 1 Date: Fri, 25 Oct 2019 15:29:55 -0400 From: "Christian Biesinger (Code Review)" To: gdb-patches@sourceware.org Cc: Christian Biesinger Message-ID: Auto-Submitted: auto-generated X-Gerrit-MessageType: newchange Subject: [review] Precompute hash value for symbol_set_names X-Gerrit-Change-Id: I044449e7eb60cffc1c43efd3412f2b485bd9faac X-Gerrit-Change-Number: 307 X-Gerrit-ChangeURL: X-Gerrit-Commit: fb027750cd4c59cbdc5ccc4633ff0e28fc0c07cb References: Reply-To: cbiesinger@google.com, cbiesinger@google.com, gdb-patches@sourceware.org MIME-Version: 1.0 Content-Disposition: inline User-Agent: Gerrit/3.0.3 Change URL: https://gnutoolchain-gerrit.osci.io/r/c/binutils-gdb/+/307 ...................................................................... Precompute hash value for symbol_set_names We can also compute the hash for the mangled name on a background thread so make this function even faster (about a 7% speedup). gdb/ChangeLog: 2019-10-03 Christian Biesinger * minsyms.c (minimal_symbol_reader::install): Also compute the hash of the mangled name on the background thread. * symtab.c (symbol_set_names): Allow passing in the hash of the linkage_name. * symtab.h (symbol_set_names): Likewise. Change-Id: I044449e7eb60cffc1c43efd3412f2b485bd9faac --- M gdb/minsyms.c M gdb/symtab.c M gdb/symtab.h 3 files changed, 22 insertions(+), 6 deletions(-) diff --git a/gdb/minsyms.c b/gdb/minsyms.c index bfcd5d5..51894b2 100644 --- a/gdb/minsyms.c +++ b/gdb/minsyms.c @@ -1249,6 +1249,10 @@ return (mcount); } +struct computed_hash_values { + hashval_t mangled_name_hash; +}; + /* Build (or rebuild) the minimal symbol hash tables. This is necessary after compacting or sorting the table since the entries move around thus causing the internal minimal_symbol pointers to become jumbled. */ @@ -1365,6 +1369,8 @@ std::mutex demangled_mutex; #endif + std::vector hash_values (mcount); + msymbols = m_objfile->per_bfd->msymbols.get (); gdb::parallel_for_each (&msymbols[0], &msymbols[mcount], @@ -1381,6 +1387,9 @@ (msym, demangled_name, &m_objfile->per_bfd->storage_obstack); msym->name_set = 1; + + size_t idx = msym - msymbols; + hash_values[idx].mangled_name_hash = htab_hash_string (msym->name); } } { @@ -1391,9 +1400,11 @@ #endif for (minimal_symbol *msym = start; msym < end; ++msym) { + size_t idx = msym - msymbols; symbol_set_names (msym, msym->name, strlen (msym->name), 0, - m_objfile->per_bfd); + m_objfile->per_bfd, + hash_values[idx].mangled_name_hash); } } }); diff --git a/gdb/symtab.c b/gdb/symtab.c index abc6a77..06d8370 100644 --- a/gdb/symtab.c +++ b/gdb/symtab.c @@ -825,7 +825,7 @@ void symbol_set_names (struct general_symbol_info *gsymbol, const char *linkage_name, int len, bool copy_name, - struct objfile_per_bfd_storage *per_bfd) + struct objfile_per_bfd_storage *per_bfd, hashval_t hash) { struct demangled_name_entry **slot; /* A 0-terminated copy of the linkage name. */ @@ -868,9 +868,11 @@ linkage_name_copy = linkage_name; struct demangled_name_entry entry (gdb::string_view (linkage_name_copy, len)); + if (hash == 0) + hash = hash_demangled_name_entry (&entry); slot = ((struct demangled_name_entry **) - htab_find_slot (per_bfd->demangled_names_hash.get (), - &entry, INSERT)); + htab_find_slot_with_hash (per_bfd->demangled_names_hash.get (), + &entry, hash, INSERT)); /* If this name is not in the hash table, add it. */ if (*slot == NULL diff --git a/gdb/symtab.h b/gdb/symtab.h index 7d41de9..48392b9 100644 --- a/gdb/symtab.h +++ b/gdb/symtab.h @@ -514,13 +514,16 @@ (symbol)->ginfo.name = (linkage_name) /* Set the linkage and natural names of a symbol, by demangling - the linkage name. */ + the linkage name. Optionally, HASH can be set to the value + of htab_hash_string (linkage_name) (if nullterminated), to + speed up this function. */ #define SYMBOL_SET_NAMES(symbol,linkage_name,len,copy_name,objfile) \ symbol_set_names (&(symbol)->ginfo, linkage_name, len, copy_name, \ (objfile)->per_bfd) extern void symbol_set_names (struct general_symbol_info *symbol, const char *linkage_name, int len, bool copy_name, - struct objfile_per_bfd_storage *per_bfd); + struct objfile_per_bfd_storage *per_bfd, + hashval_t hash = 0); /* Now come lots of name accessor macros. Short version as to when to use which: Use SYMBOL_NATURAL_NAME to refer to the name of the