From: Weimin Pan <weimin.pan@oracle.com>
To: Simon Marchi <simark@simark.ca>, gdb-patches@sourceware.org
Cc: Yao Qi <qiyaoltc@gmail.com>
Subject: Re: [PATCH PR gdb/18071] TLS variables can't be resolved on aarch64-linux-gnu
Date: Mon, 19 Mar 2018 19:36:00 -0000 [thread overview]
Message-ID: <6c9fb8cc-eb2a-86c3-9e34-fac7c97f6b2f@oracle.com> (raw)
In-Reply-To: <402e4a8c-eaf9-a31e-9925-3125f8d149f9@simark.ca>
On 3/17/2018 9:52 AM, Simon Marchi wrote:
> On 2017-11-02 08:38 PM, Weimin Pan wrote:
>> Running the test case with upstream gdb shows two failures:
>>
>> (1) Receiving different error messages when printing TLS variable before
>> program runs - because the ARM compiler does not emit dwarf attribute
>> DW_AT_location for TLS, the result is expected and the baseline may
>> need to be changed for aarch64.
>>
>> (2) Using "info address" command on C++ static TLS object resulted in
>> "symbol unresolved" error - below is a snippet from the test case:
>>
>> class K {
>> public:
>> static __thread int another_thread_local;
>> };
>>
>> __thread int K::another_thread_local;
>>
>> (gdb) info address K::another_thread_local
>> Symbol "K::another_thread_local" is unresolved.
>>
>> This patch contains fix for (2).
>>
>> Function info_address_command() handles the "info address" command and
>> calls lookup_minimal_symbol_and_objfile() to find sym's symbol entry in
>> mininal symbol table if SYMBOL_COMPUTED_OPS (sym) is false. Problem is
>> that function lookup_minimal_symbol_and_objfile() only looked up an
>> objfile's minsym ordinary hash table, not its demangled hash table, which
>> was the reason why the C++ name was not found.
>>
>> The fix is to call lookup_minimal_symbol(), which already looks up entries
>> in both minsym's hash tables, to find names when traversing the object file
>> list in lookup_minimal_symbol_and_objfile().
>>
>> Tested in both aarch64-linux-gnu and amd64-linux-gnu. No regressions.
> Hi Weimin,
>
> I would be ok with making lookup_minimal_symbol_and_objfile look through demangled
> names as well, I don't see a need for it to only search through linkage names.
> I don't think it should break any user of that function, since it would mean that
> there is a clash between a mangled name and a demangled name, I don't think this is
> likely.
Hi Simon,
Yes, you're right that a name clash is unlikely to happen. I think you have
a better suggestion, at the end of your email, to leave this function alone.
But it'd be good to update the doc for lookup_minimal_symbol_and_objfile(),
where the term "linkage name" should be replaced with either "ordinary" or
"demangled" because it seems to me that "linkage name" == "mangled name".
> The doc of lookup_minimal_symbol_and_objfile in minsyms.h should be updated.
>
> So this now works:
>
> (gdb) info address K::another_thread_local2
> Symbol "K::another_thread_local2" is a thread-local variable at offset 0x4 in the thread-local storage for `/home/simark/build/binutils-gdb/gdb/test'.
>
> But printing the variable doesn't:
>
> (gdb) p K::another_thread_local2
> Cannot find thread-local storage for process 8959, executable file /home/simark/build/binutils-gdb/gdb/test:
> Cannot find thread-local variables on this target
>
> Is this also what you see? If the scope of this patch is to only fix "info address",
> could you change the title of the patch to reflect it? Otherwise it sounds like
> it fixes actually accessing/printing the variable as well.
Yes, printing of a TLS fails on all platforms, not just on aarch64.
How about changing the title to:
  [PATCH PR gdb/18071] aarch64: "info" command can't resolve TLS variables
>> gdb/ChangeLog | 5 +++++
>> gdb/minsyms.c | 17 +++--------------
>> 2 files changed, 8 insertions(+), 14 deletions(-)
>>
>> diff --git a/gdb/ChangeLog b/gdb/ChangeLog
>> index 4b292e0..2f630bc 100644
>> --- a/gdb/ChangeLog
>> +++ b/gdb/ChangeLog
>> @@ -1,3 +1,8 @@
>> +2017-11-01 Weimin Pan <weimin.pan@oracle.com>
>> +
>> + * minsyms.c (lookup_minimal_symbol_and_objfile): Use
>> + lookup_minimal_symbol() to find symbol entry.
>> +
>> 2017-10-27 Keith Seitz <keiths@redhat.com>
>>
>> * breakpoint.c (print_breakpoint_location): Use the symbol saved
>> diff --git a/gdb/minsyms.c b/gdb/minsyms.c
>> index 37edbd8..4edd8b1 100644
>> --- a/gdb/minsyms.c
>> +++ b/gdb/minsyms.c
>> @@ -881,23 +881,12 @@ lookup_minimal_symbol_and_objfile (const char *name)
>> {
>> struct bound_minimal_symbol result;
>> struct objfile *objfile;
>> - unsigned int hash = msymbol_hash (name) % MINIMAL_SYMBOL_HASH_SIZE;
>>
>> ALL_OBJFILES (objfile)
>> {
>> - struct minimal_symbol *msym;
>> -
>> - for (msym = objfile->per_bfd->msymbol_hash[hash];
>> - msym != NULL;
>> - msym = msym->hash_next)
>> - {
>> - if (strcmp (MSYMBOL_LINKAGE_NAME (msym), name) == 0)
>> - {
>> - result.minsym = msym;
>> - result.objfile = objfile;
>> - return result;
>> - }
>> - }
>> + result = lookup_minimal_symbol (name, NULL, objfile);
>> + if (result.minsym != NULL)
>> + return result;
>> }
> Is this code equivalent to calling lookup_minimal_symbol (name, NULL, NULL) ? If
> so, there's already lookup_bound_minimal_symbol that does the same, so maybe we
> can just drop lookup_minimal_symbol_and_objfile and use lookup_bound_minimal_symbol.
Yes, it turns out lookup_minimal_symbol_and_objfile(name) is equivalent to
calling lookup_minimal_symbol (name, NULL, NULL). We can replace the call in
info_address_command() with either lookup_minimal_symbol (name, NULL, NULL)
or lookup_bound_minimal_symbol(name). Calling either one looks like a
better fix.
>
> We could also just have lookup_minimal_symbol with parameters that default to nullptr.
> It is not clear at all to have lookup_bound_minimal_symbol and lookup_minimal_symbol
> that both return a bound_minimal_symbol, that's quite misleading.
I don't know the rational behind having these two functions which get
called in
quite a few places. Yes, having default arguments for
lookup_minimal_symbol()
will be another option.
Thanks very much for your comments.
Weimin
>
> Simon
next prev parent reply other threads:[~2018-03-19 19:36 UTC|newest]
Thread overview: 18+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-11-03 0:54 Weimin Pan
2017-11-16 9:13 ` Yao Qi
2017-11-16 14:59 ` Yao Qi
2017-11-16 22:40 ` Wei-min Pan
2017-11-21 15:36 ` Yao Qi
2017-11-29 1:35 ` Weimin Pan
2018-03-17 16:52 ` Simon Marchi
2018-03-19 19:36 ` Weimin Pan [this message]
2018-03-22 4:22 ` Simon Marchi
2018-03-22 18:18 ` Wei-min Pan
2018-03-22 20:16 ` Simon Marchi
2018-03-22 20:49 ` Wei-min Pan
2018-03-24 3:10 ` Simon Marchi
2018-03-24 19:45 ` Wei-min Pan
2018-03-24 19:52 ` Simon Marchi
2018-03-24 20:16 ` Wei-min Pan
2018-03-24 20:44 ` Simon Marchi
2018-03-24 21:42 ` Wei-min Pan
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=6c9fb8cc-eb2a-86c3-9e34-fac7c97f6b2f@oracle.com \
--to=weimin.pan@oracle.com \
--cc=gdb-patches@sourceware.org \
--cc=qiyaoltc@gmail.com \
--cc=simark@simark.ca \
/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