diff options
author | Joel Brobecker <brobecker@gnat.com> | 2012-09-11 21:26:16 +0000 |
---|---|---|
committer | Joel Brobecker <brobecker@gnat.com> | 2012-09-11 21:26:16 +0000 |
commit | d9eaeb59a428f57acfe2877e3d21df5fac59fbe3 (patch) | |
tree | a7f661b937237d77fe2f15225c182eb5a0bc7de0 /gdb/printcmd.c | |
parent | a83e9154c2f2a7c2c3a399c25c3931560a990d40 (diff) | |
download | gdb-d9eaeb59a428f57acfe2877e3d21df5fac59fbe3.zip gdb-d9eaeb59a428f57acfe2877e3d21df5fac59fbe3.tar.gz gdb-d9eaeb59a428f57acfe2877e3d21df5fac59fbe3.tar.bz2 |
Name of symbol missing when printing global variable's address
The build_address_symbolic funnction filters out data symbols if
their size is set to zero. But the problem is that the COFF symbol
table (for instance) does not provide any size information, leaving
the size to its default value of zero, thus always triggering
the filter.
This shows up when trying to print the address of a global variable
when debugging a Windows executable, for instance.
gdb/ChangeLog:
* symtab.h (struct minimal_symbol) [has_size]: New field.
(MSYMBOL_SIZE): Adjust to forbid macro from being used as lvalue.
(SET_MSYMBOL_SIZE, MSYMBOL_HAS_SIZE): New macros.
* printcmd.c (build_address_symbolic): Only filter out zero-sized
minimal symbols if the symbol's size is actually known.
* minsyms.c (prim_record_minimal_symbol_full): Adjust setting
of msymbol's size field. Add comment.
* elfread.c (elf_symtab_read, elf_rel_plt_read): Use
SET_MSYMBOL_SIZE to set the minimal symbol size.
Diffstat (limited to 'gdb/printcmd.c')
-rw-r--r-- | gdb/printcmd.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/gdb/printcmd.c b/gdb/printcmd.c index d5b5b63..9e8cd65 100644 --- a/gdb/printcmd.c +++ b/gdb/printcmd.c @@ -680,6 +680,7 @@ build_address_symbolic (struct gdbarch *gdbarch, } if (msymbol != NULL + && MSYMBOL_HAS_SIZE (msymbol) && MSYMBOL_SIZE (msymbol) == 0 && MSYMBOL_TYPE (msymbol) != mst_text && MSYMBOL_TYPE (msymbol) != mst_text_gnu_ifunc |