Mirror of the gdb-patches mailing list
 help / color / mirror / Atom feed
* RFC: Skip declarations in "info variables"
@ 2009-11-13 21:44 Daniel Jacobowitz
  2009-11-13 22:27 ` Joel Brobecker
  2009-11-14  9:36 ` Eli Zaretskii
  0 siblings, 2 replies; 8+ messages in thread
From: Daniel Jacobowitz @ 2009-11-13 21:44 UTC (permalink / raw)
  To: gdb-patches

This has bugged me for a while, but today it caused me a test failure:
I added a reference to an otherwise unused variable in
gdb.base/included.c.  The info var integer output became:

All variables matching regular expression "integer":

File .../included.c:
static int integer;
int integer;

There's two problems here.  First, one of the copies is static.  The
dwarf2read.c portion of the patch below fixes this.  We now add
external symbols without a location to list_in_scope, in order to
correctly support:

  int x;
  {
    extern int x;
    // x here references the global
  }

But that caused us to display this as a static variable:

extern int x;

So we should special-case file scope variables.

The second problem is that integer is listed twice.  Jan pointed me to
GCC PR 37982; the file has a declaration and definition for the
variable if it is referenced (only a definition, otherwise).
I don't think we should display the declaration.  So I've changed
search_symbols not to display variables of class LOC_UNRESOLVED, and
updated the documentation to match.  While this is a change of
behavior, I don't think it's problematic.

Any comments?  OK to commit?

Tested on arm-none-eabi and x86_64-linux.

2009-11-13  Daniel Jacobowitz  <dan@codesourcery.com>

	* dwarf2read.c (new_symbol): Add file-scope external unresolved
	symbols to global_symbols.
	* symtab.c (search_symbols): Skip LOC_UNRESOLVED symbols.

	* gdb.texinfo (Symbols): "info variables" prints definitions, not
	declarations.

---
 gdb/doc/gdb.texinfo |    2 +-
 gdb/dwarf2read.c    |    9 ++++++++-
 gdb/symtab.c        |    5 ++++-
 3 files changed, 13 insertions(+), 3 deletions(-)

Index: src/gdb/dwarf2read.c
===================================================================
--- src.orig/gdb/dwarf2read.c	2009-11-13 16:22:50.000000000 -0500
+++ src/gdb/dwarf2read.c	2009-11-13 16:27:57.000000000 -0500
@@ -8441,8 +8441,15 @@ new_symbol (struct die_info *die, struct
 	      if (attr2 && (DW_UNSND (attr2) != 0)
 		  && dwarf2_attr (die, DW_AT_type, cu) != NULL)
 		{
+		  struct pending **list_to_add;
+
+		  /* A variable with DW_AT_external is never static, but it
+		     may be block-scoped.  */
+		  list_to_add = (cu->list_in_scope == &file_symbols
+				 ? &global_symbols : cu->list_in_scope);
+
 		  SYMBOL_CLASS (sym) = LOC_UNRESOLVED;
-		  add_symbol_to_list (sym, cu->list_in_scope);
+		  add_symbol_to_list (sym, list_to_add);
 		}
 	      else if (!die_is_declaration (die, cu))
 		{
Index: src/gdb/symtab.c
===================================================================
--- src.orig/gdb/symtab.c	2009-11-13 16:22:50.000000000 -0500
+++ src/gdb/symtab.c	2009-11-13 16:27:57.000000000 -0500
@@ -3234,7 +3234,9 @@ search_symbols (char *regexp, domain_enu
 		&& ((regexp == NULL
 		     || re_exec (SYMBOL_NATURAL_NAME (*psym)) != 0)
 		    && ((kind == VARIABLES_DOMAIN && SYMBOL_CLASS (*psym) != LOC_TYPEDEF
-			 && SYMBOL_CLASS (*psym) != LOC_BLOCK)
+			 && SYMBOL_CLASS (*psym) != LOC_UNRESOLVED
+			 && SYMBOL_CLASS (*psym) != LOC_BLOCK
+			 && SYMBOL_CLASS (*psym) != LOC_CONST)
 			|| (kind == FUNCTIONS_DOMAIN && SYMBOL_CLASS (*psym) == LOC_BLOCK)
 			|| (kind == TYPES_DOMAIN && SYMBOL_CLASS (*psym) == LOC_TYPEDEF))))
 	      {
@@ -3310,6 +3312,7 @@ search_symbols (char *regexp, domain_enu
 		  && ((regexp == NULL
 		       || re_exec (SYMBOL_NATURAL_NAME (sym)) != 0)
 		      && ((kind == VARIABLES_DOMAIN && SYMBOL_CLASS (sym) != LOC_TYPEDEF
+			   && SYMBOL_CLASS (sym) != LOC_UNRESOLVED
 			   && SYMBOL_CLASS (sym) != LOC_BLOCK
 			   && SYMBOL_CLASS (sym) != LOC_CONST)
 			  || (kind == FUNCTIONS_DOMAIN && SYMBOL_CLASS (sym) == LOC_BLOCK)
Index: src/gdb/doc/gdb.texinfo
===================================================================
--- src.orig/gdb/doc/gdb.texinfo	2009-11-13 16:28:20.000000000 -0500
+++ src/gdb/doc/gdb.texinfo	2009-11-13 16:28:43.000000000 -0500
@@ -12920,7 +12920,7 @@ that conflict with the regular expressio
 
 @kindex info variables
 @item info variables
-Print the names and data types of all variables that are declared
+Print the names and data types of all variables that are defined
 outside of functions (i.e.@: excluding local variables).
 
 @item info variables @var{regexp}

-- 
Daniel Jacobowitz
CodeSourcery


^ permalink raw reply	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2009-12-28 21:31 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2009-11-13 21:44 RFC: Skip declarations in "info variables" Daniel Jacobowitz
2009-11-13 22:27 ` Joel Brobecker
2009-11-14  9:36 ` Eli Zaretskii
2009-11-14 15:54   ` Daniel Jacobowitz
2009-11-14 16:03     ` Paul Pluzhnikov
2009-12-28 21:05   ` Daniel Jacobowitz
2009-12-28 21:21     ` Eli Zaretskii
2009-12-28 21:31       ` Daniel Jacobowitz

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox