Mirror of the gdb-patches mailing list
 help / color / mirror / Atom feed
From: Michael Snyder <msnyder@vmware.com>
To: Paul Pluzhnikov <ppluzhnikov@google.com>
Cc: "gdb-patches@sourceware.org" <gdb-patches@sourceware.org>
Subject: Re: [RFA] [patch] 'info symbol' to print more info
Date: Sat, 15 Nov 2008 17:00:00 -0000	[thread overview]
Message-ID: <491DF12A.5090903@vmware.com> (raw)
In-Reply-To: <20081114204617.A4A533A6B15@localhost>

Paul Pluzhnikov wrote:
> Greetings,
> 
> Currently, 'info symbol' and 'maintenance translate-address' print
> just the symbol+offset:
> 
> (gdb) maint translate-address 0x2aaaac1f5880
> exit+0
> (gdb) info symbol 0x2aaaac1f5880
> exit in section .text
> 
> That's nice, but when I have 100s of shared libraries loaded,
> I want to know more.
> 
> Attached patch results in:
> 
> (gdb) maint translate-address 0x2aaaac1f5880
> exit+0 section .text in /usr/lib64/libc.so.6
> (gdb) info symbol 0x2aaaac1f5880
> exit in section .text of /usr/lib64/libc.so.6
> 
> Regtested on x86_64 with no failures.
> 
> Ok to commit?

I like it!

Just one suggestion (and suggestion only) -- since the exec_file
is sort of the default/common case, do you think it would be a
good idea to check if it's the exec_file, and omit the objfile
information if so?


> 2008-11-14  Paul Pluzhnikov  <ppluzhnikov@google.com>
> 
> 	* printcmd.c (sym_info): Print object name.
> 	* maint.c (maintenance_translate_address): Likewise.
> 	
> 
> Index: gdb/maint.c
> ===================================================================
> RCS file: /cvs/src/src/gdb/maint.c,v
> retrieving revision 1.68
> diff -u -p -u -r1.68 maint.c
> --- gdb/maint.c	30 Oct 2008 20:35:30 -0000	1.68
> +++ gdb/maint.c	14 Nov 2008 20:39:48 -0000
> @@ -484,9 +484,18 @@ maintenance_translate_address (char *arg
>      sym = lookup_minimal_symbol_by_pc (address);
>  
>    if (sym)
> -    printf_filtered ("%s+%s\n",
> -		     SYMBOL_PRINT_NAME (sym),
> -		     pulongest (address - SYMBOL_VALUE_ADDRESS (sym)));
> +    {
> +      printf_filtered ("%s+%s",
> +		       SYMBOL_PRINT_NAME (sym),
> +		       pulongest (address - SYMBOL_VALUE_ADDRESS (sym)));
> +      if ((sect = SYMBOL_OBJ_SECTION(sym)))
> +	{
> +	  printf_filtered (_(" section %s"), sect->the_bfd_section->name);
> +	  if (sect->objfile && sect->objfile->name)
> +	    printf_filtered (_(" in %s"), sect->objfile->name);
> +	}
> +      printf_filtered (_("\n"));
> +    }
>    else if (sect)
>      printf_filtered (_("no symbol at %s:0x%s\n"),
>  		     sect->the_bfd_section->name, paddr (address));
> Index: gdb/printcmd.c
> ===================================================================
> RCS file: /cvs/src/src/gdb/printcmd.c,v
> retrieving revision 1.136
> diff -u -p -u -r1.136 printcmd.c
> --- gdb/printcmd.c	13 Nov 2008 22:26:15 -0000	1.136
> +++ gdb/printcmd.c	14 Nov 2008 20:39:48 -0000
> @@ -1026,6 +1026,8 @@ sym_info (char *arg, int from_tty)
>  	  printf_filtered (_("%s overlay "),
>  			   section_is_mapped (osect) ? "mapped" : "unmapped");
>  	printf_filtered (_("section %s"), osect->the_bfd_section->name);
> +	if (osect->objfile && osect->objfile->name)
> +	  printf_filtered (_(" of %s"), osect->objfile->name);
>  	printf_filtered ("\n");
>        }
>    }


  reply	other threads:[~2008-11-14 21:45 UTC|newest]

Thread overview: 16+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2008-11-15 16:15 Paul Pluzhnikov
2008-11-15 17:00 ` Michael Snyder [this message]
2008-11-15 17:22   ` Paul Pluzhnikov
2008-11-15 18:51     ` Michael Snyder
2008-11-15 23:16       ` Paul Pluzhnikov
2008-11-15 23:35         ` Andreas Schwab
2008-11-16  1:35         ` Eli Zaretskii
2008-11-16  1:38           ` Paul Pluzhnikov
2008-11-16  8:20             ` Joel Brobecker
2008-11-17 22:37               ` Paul Pluzhnikov
2008-11-17 23:35                 ` Daniel Jacobowitz
2008-11-18 16:07                   ` Paul Pluzhnikov
2008-11-18 19:55                     ` Eli Zaretskii
2008-11-19  4:20                     ` Joel Brobecker
2008-11-19 12:45                       ` Paul Pluzhnikov
2008-11-15 17:40 ` Eli Zaretskii

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=491DF12A.5090903@vmware.com \
    --to=msnyder@vmware.com \
    --cc=gdb-patches@sourceware.org \
    --cc=ppluzhnikov@google.com \
    /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