diff --git a/gdb/ChangeLog b/gdb/ChangeLog index b010c81ce6..83e649e469 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,8 @@ +2014-12-05 Jan Kratochvil + + * symtab.c (lookup_symbol_in_objfile_symtabs): New declaration. + (lookup_global_symbol_from_objfile): Call it. + 2014-12-05 Jan Kratochvil Remove const from struct objfile *. diff --git a/gdb/symtab.c b/gdb/symtab.c index c697b1bcca..c07b90268d 100644 --- a/gdb/symtab.c +++ b/gdb/symtab.c @@ -79,6 +79,11 @@ struct symbol *lookup_local_symbol (const char *name, const domain_enum domain, enum language language); +static struct symbol * + lookup_symbol_in_objfile_symtabs (struct objfile *objfile, + int block_index, const char *name, + const domain_enum domain); + static struct symbol *lookup_symbol_via_quick_fns (struct objfile *objfile, int block_index, @@ -1546,24 +1551,12 @@ lookup_global_symbol_from_objfile (struct objfile *main_objfile, objfile; objfile = objfile_separate_debug_iterate (main_objfile, objfile)) { - struct compunit_symtab *cust; struct symbol *sym; - - /* Go through symtabs. */ - ALL_OBJFILE_COMPUNITS (objfile, cust) - { - const struct blockvector *bv; - const struct block *block; - - bv = COMPUNIT_BLOCKVECTOR (cust); - block = BLOCKVECTOR_BLOCK (bv, GLOBAL_BLOCK); - sym = block_lookup_symbol (block, name, domain); - if (sym) - { - block_found = block; - return fixup_symbol_section (sym, objfile); - } - } + + sym = lookup_symbol_in_objfile_symtabs (objfile, GLOBAL_BLOCK, name, + domain); + if (sym != NULL) + return sym; sym = lookup_symbol_via_quick_fns (objfile, GLOBAL_BLOCK, name, domain); if (sym)