[PATCH][gdb/symtab] Ignore cold clones
Simon Marchi
simon.marchi@polymtl.ca
Mon May 31 14:26:28 GMT 2021
On 2021-05-31 10:15 a.m., Tom de Vries wrote:
> Hi,
>
> Consider the test-case contained in this patch, compiled for c using gcc-10:
> ...
> $ gcc-10 -x c src/gdb/testsuite/gdb.cp/cold-clone.cc -O2 -g -Wall -Wextra
> ...
>
> When setting a breakpoint on foo, we get one breakpoint location:
> ...
> $ gdb -q -batch a.out -ex "b foo"
> Breakpoint 1 at 0x400560: file cold-clone.cc, line 28.
> ...
>
> However, when we compile for c++ instead, we get two breakpoint locations:
> ...
> $ gdb -q -batch a.out -ex "b foo" -ex "info break"
> Breakpoint 1 at 0x400430: foo. (2 locations)
> Num Type Disp Enb Address What
> 1 breakpoint keep y <MULTIPLE>
> 1.1 y 0x0000000000400430 in foo() at cold-clone.cc:30
> 1.2 y 0x0000000000400560 in foo() at cold-clone.cc:28
> ...
>
> The additional breakpoint location at 0x400430 corresponds to the cold clone:
> ...
> $ nm a.out | grep foo
> 0000000000400560 t _ZL3foov
> 0000000000400430 t _ZL3foov.cold
> ...
> which demangled looks like this:
> ...
> $ nm -C a.out | grep foo
> 0000000000400560 t foo()
> 0000000000400430 t foo() [clone .cold]
> ...
>
> [ Or, in the case of the cc1 mentioned in PR23710:
> ...
> $ nm cc1 | grep do_rpo_vn.*cold
> 000000000058659d t \
> _ZL9do_rpo_vnP8functionP8edge_defP11bitmap_headbb.cold.138
> $ nm -C cc1 | grep do_rpo_vn.*cold
> 000000000058659d t \
> do_rpo_vn(function*, edge_def*, bitmap_head*, bool, bool) [clone .cold.138]
> ... ]
>
> The cold clone is a part of the function that is split off from the rest of
> the function because it's considered cold (not frequently executed). So while
> the symbol points to code that is part of a function, it doesn't point to a
> function entry, so the desirable behaviour for "break foo" is to ignore this
> symbol.
>
> When compiling for c, the symbol "foo.cold" is entered as minimal symbol
> with the search name "foo.cold", and the lookup using "foo" fails to find that
> symbol.
>
> But when compiling for c++, the symbol "foo.cold" is entered as minimal symbol
> with both the mangled and demangled name, and for the demangled name
> "foo() [clone .cold]" we get the search name "foo" (because
> cp_search_name_hash stops hashing at '('), and the lookup using "foo" succeeds.
>
> Fix this by recognizing the cold clone suffix and returning false for such a
> minimal symbol in msymbol_is_function.
>
> Tested on x86_64-linux.
>
> Any comments?
Is this related to
https://sourceware.org/pipermail/gdb-patches/2021-May/179371.html
?
Simon
More information about the Gdb-patches
mailing list