summaryrefslogtreecommitdiff
path: root/gdb/symmisc.c
diff options
context:
space:
mode:
Diffstat (limited to 'gdb/symmisc.c')
-rw-r--r--gdb/symmisc.c42
1 files changed, 26 insertions, 16 deletions
diff --git a/gdb/symmisc.c b/gdb/symmisc.c
index 5d50b0fce08..313f65dafb5 100644
--- a/gdb/symmisc.c
+++ b/gdb/symmisc.c
@@ -20,7 +20,6 @@ anyone else from sharing it farther. Help stamp out software hoarding!
#include "defs.h"
-#include "initialize.h"
#include "symtab.h"
#include <stdio.h>
@@ -28,7 +27,6 @@ anyone else from sharing it farther. Help stamp out software hoarding!
static void free_symtab ();
-START_FILE
/* Free all the symtabs that are currently installed,
and all storage associated with them.
@@ -329,8 +327,7 @@ relocate_source (sp)
RELOCATE (sp->name);
for (i = 0; i < nitems; i++)
- if (sp->contents.item[i] > 0)
- TEXT_RELOCATE (sp->contents.item[i]);
+ TEXT_RELOCATE (sp->contents.item[i].pc);
}
/* Read symsegs from file named NAME open on DESC,
@@ -358,9 +355,12 @@ read_symsegs (desc, name)
len = myread (desc, &root, sizeof root);
if (len == 0 || root.format == 0)
break;
- if (root.format != 1 ||
+ /* format 1 was ok for the original gdb, but since the size of the
+ type structure changed when C++ support was added, it can no
+ longer be used. Accept only format 2. */
+ if (root.format != 2 ||
root.length < sizeof root)
- error ("Invalid symbol segment format code");
+ error ("\nInvalid symbol segment format code");
data = (char *) xmalloc (root.length);
bcopy (&root, data, sizeof root);
len = myread (desc, data + sizeof root,
@@ -380,6 +380,7 @@ static int block_depth ();
static void print_spaces ();
static void print_symbol ();
+void
print_symtabs (filename)
char *filename;
{
@@ -411,12 +412,8 @@ print_symtabs (filename)
l = LINETABLE (s);
len = l->nitems;
for (i = 0; i < len; i++)
- {
- if (l->item[i] < 0)
- line = - l->item[i] - 1;
- else
- fprintf (outfile, " line %d at %x\n", ++line, l->item[i]);
- }
+ fprintf (outfile, " line %d at %x\n", l->item[i].line,
+ l->item[i].pc);
/* Now print the block info. */
fprintf (outfile, "\nBlockvector:\n\n");
bv = BLOCKVECTOR (s);
@@ -522,7 +519,7 @@ print_symbol (symbol, depth, outfile)
break;
case LOC_REGPARM:
- fprintf (outfile, "parmameter register %d,", SYMBOL_VALUE (symbol));
+ fprintf (outfile, "parameter register %d,", SYMBOL_VALUE (symbol));
break;
case LOC_LOCAL:
@@ -557,11 +554,24 @@ block_depth (block)
return i;
}
-static
-initialize ()
+/*
+ * Free all partial_symtab storage.
+ */
+void
+free_all_psymtabs()
+{
+ obstack_free (psymbol_obstack, 0);
+ obstack_init (psymbol_obstack);
+ partial_symtab_list = (struct partial_symtab *) 0;
+}
+
+void
+_initialize_symmisc ()
{
+ symtab_list = (struct symtab *) 0;
+ partial_symtab_list = (struct partial_symtab *) 0;
+
add_com ("printsyms", class_obscure, print_symtabs,
"Print dump of current symbol definitions to file OUTFILE.");
}
-END_FILE