From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (qmail 17304 invoked by alias); 12 Nov 2014 22:31:41 -0000 Mailing-List: contact gdb-prs-help@sourceware.org; run by ezmlm Precedence: bulk List-Id: List-Subscribe: List-Archive: List-Post: List-Help: , Sender: gdb-prs-owner@sourceware.org Received: (qmail 17276 invoked by uid 48); 12 Nov 2014 22:31:40 -0000 From: "dje at google dot com" To: gdb-prs@sourceware.org Subject: [Bug symtab/17591] New: dwarf2read.c:find_slot_in_mapped_hash needs to handle "(anonymous namespace)" Date: Wed, 12 Nov 2014 22:31:00 -0000 X-Bugzilla-Reason: CC X-Bugzilla-Type: new X-Bugzilla-Watch-Reason: None X-Bugzilla-Product: gdb X-Bugzilla-Component: symtab X-Bugzilla-Version: 7.8 X-Bugzilla-Keywords: X-Bugzilla-Severity: normal X-Bugzilla-Who: dje at google dot com X-Bugzilla-Status: NEW X-Bugzilla-Priority: P2 X-Bugzilla-Assigned-To: unassigned at sourceware dot org X-Bugzilla-Target-Milestone: --- X-Bugzilla-Flags: X-Bugzilla-Changed-Fields: bug_id short_desc product version bug_status bug_severity priority component assigned_to reporter Message-ID: Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 7bit X-Bugzilla-URL: http://sourceware.org/bugzilla/ Auto-Submitted: auto-generated MIME-Version: 1.0 X-SW-Source: 2014-q4/txt/msg00241.txt.bz2 https://sourceware.org/bugzilla/show_bug.cgi?id=17591 Bug ID: 17591 Summary: dwarf2read.c:find_slot_in_mapped_hash needs to handle "(anonymous namespace)" Product: gdb Version: 7.8 Status: NEW Severity: normal Priority: P2 Component: symtab Assignee: unassigned at sourceware dot org Reporter: dje at google dot com I was debugging a perf issue and found this in find_slot_in_mapped_hash: if (current_language->la_language == language_cplus || current_language->la_language == language_java || current_language->la_language == language_fortran) { /* NAME is already canonical. Drop any qualifiers as .gdb_index does not contain any. */ const char *paren = strchr (name, '('); if (paren) { char *dup; dup = xmalloc (paren - name + 1); memcpy (dup, name, paren - name); dup[paren - name] = 0; make_cleanup (xfree, dup); name = dup; } } What if name is "(anonymous namespace)" ? For the program at hand, this results in symbol table entry 0 which has 1085 entries. [ 0] : 4 [static, function] 5 [static, function] 6 [static, function] ... some global functions 2737 [static, function] 2739 [static, function] 2743 [static, function] None of the CUs for these entries define anonymous namespace, but since we're looking up in VAR_DOMAIN the index returns a match and we expand the CU. While we should fix find_slot_in_mapped_hash, there is a side issue of doing a general purpose lookup (VAR_DOMAIN) when we have (or should have) enough knowledge to do a more specific lookup (we're looking for a namespace(/type) not a function). -- You are receiving this mail because: You are on the CC list for the bug.