This is the mail archive of the gdb-patches@sources.redhat.com mailing list for the GDB project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

[RFA] minsyms.c: Fix switching to GNU v3 ABI


Hi,

I was debugging a situation, in which an C++ object file has been build
using v3 ABI, but GDB did not recognize it and was assuming v2 ABI.  The
target system is sh-elf, the compiler gcc 3.4.

What I found is this:

- The C++ ABI is set to v2 by default (gnu-v2-abi.c, _initialize_gnu_v2_abi).

- While reading symbols from the object file, at one point elf_symfile_read()
  (elfread.c) is called.

- elf_symfile_read() calls elf_symtab_read() which calls
  record_minimal_symbol() which calls prim_record_minimal_symbol_and_info().

- In prim_record_minimal_symbol_and_info(), the symbol language is set to
  language_auto unconditionally.

- After returning from elf_symtab_read(), install_minimal_symbols() is
  called.  At the end of install_minimal_symbols() a loop over all msymbols
  tries to figure out if v3 ABI is used.  This is done by requesting the
  demangeled name calling SYMBOL_DEMANGLED_NAME.

The problem is that SYMBOL_LANGUAGE is still set to language_auto and
the demangled name hasn't been generated at this point.

symbol_demangled_name() only returns the demangled name if the language is
set to a specific mangeling language and only if the demangeled name has
already been created.  This isn't the case at this point.  Ergo, the
v3 ABI isn't recognized and GDB wrongly assumes v2 ABI.

What's especially weird is the comment above install_minimal_symbols().
It implies that the function will try to demangle all symbols to set
the language correctly, but the function is not doing that.  It would
only recognize symbols which has already been demangeled but that just
don't happen.

I not sure if the below solution is entirely correct, but it solves
the problem in my case.  The solution is the create the demangled name
in the aforementioned loop in install_minimal_symbols().  This change
drops the FAIL count in the gdb.cp testsuite part from 54 to 6!


Corinna

	* minsyms.c (install_minimal_symbols): Create demangled names
	for all msymbol entries.

Index: minsyms.c
===================================================================
RCS file: /cvs/src/src/gdb/minsyms.c,v
retrieving revision 1.41
diff -u -p -r1.41 minsyms.c
--- minsyms.c	9 Feb 2004 19:13:46 -0000	1.41
+++ minsyms.c	10 Mar 2004 10:55:25 -0000
@@ -924,6 +924,8 @@ install_minimal_symbols (struct objfile 
 	       mixing ABIs then the user will need to "set cp-abi"
 	       manually.  */
 	    const char *name = SYMBOL_LINKAGE_NAME (&objfile->msymbols[i]);
+	    SYMBOL_SET_NAMES (&objfile->msymbols[i], name, strlen (name),
+			      objfile);
 	    if (name[0] == '_' && name[1] == 'Z'
 		&& SYMBOL_DEMANGLED_NAME (&objfile->msymbols[i]) != NULL)
 	      {

-- 
Corinna Vinschen
Cygwin Developer
Red Hat, Inc.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]