Sign Up
Log In
Log In
or
Sign Up
Places
All Projects
Status Monitor
Collapse sidebar
openSUSE:Step:FrontRunner
gdb.18935
gdb-symtab-use-early-continue-in-find_pc_sect_c...
Overview
Repositories
Revisions
Requests
Users
Attributes
Meta
File gdb-symtab-use-early-continue-in-find_pc_sect_compunit.patch of Package gdb.18935
[gdb/symtab] Use early continue in find_pc_sect_compunit_symtab Function find_pc_sect_compunit_symtab contains a loop: ... for (compunit_symtab *cust : obj_file->compunits ()) { ... if (...) { /* Lots of code. */ } } ... Reduce indentation level and improve readability by using early continue. Tested on x86_64-linux. gdb/ChangeLog: 2020-10-27 Tom de Vries <tdevries@suse.de> * symtab.c (find_pc_sect_compunit_symtab): Use early continue. --- gdb/symtab.c | 94 +++++++++++++++++++++++++++------------------------ 2 files changed, 54 insertions(+), 44 deletions(-) diff --git a/gdb/symtab.c b/gdb/symtab.c index a4f8239a8a1..eda33a7eb4f 100644 --- a/gdb/symtab.c +++ b/gdb/symtab.c @@ -2883,7 +2883,7 @@ struct compunit_symtab * find_pc_sect_compunit_symtab (CORE_ADDR pc, struct obj_section *section) { struct compunit_symtab *best_cust = NULL; - CORE_ADDR distance = 0; + CORE_ADDR best_cust_range = 0; struct bound_minimal_symbol msymbol; /* If we know that this is not a text address, return failure. This is @@ -2914,56 +2914,62 @@ find_pc_sect_compunit_symtab (CORE_ADDR pc, struct obj_section *section) { for (compunit_symtab *cust : obj_file->compunits ()) { - const struct block *b; - const struct blockvector *bv; + const struct blockvector *bv = COMPUNIT_BLOCKVECTOR (cust); + const struct block *global_block + = BLOCKVECTOR_BLOCK (bv, GLOBAL_BLOCK); + CORE_ADDR start = BLOCK_START (global_block); + CORE_ADDR end = BLOCK_END (global_block); + bool in_range_p = start <= pc && pc < end; + if (!in_range_p) + continue; - bv = COMPUNIT_BLOCKVECTOR (cust); - b = BLOCKVECTOR_BLOCK (bv, GLOBAL_BLOCK); + CORE_ADDR range = end - start; + if (best_cust != nullptr + && range >= best_cust_range) + /* Cust doesn't have a smaller range than best_cust, skip it. */ + continue; + + /* For an objfile that has its functions reordered, + find_pc_psymtab will find the proper partial symbol table + and we simply return its corresponding symtab. */ + /* In order to better support objfiles that contain both + stabs and coff debugging info, we continue on if a psymtab + can't be found. */ + if ((obj_file->flags & OBJF_REORDERED) && obj_file->sf) + { + struct compunit_symtab *result; + + result + = obj_file->sf->qf->find_pc_sect_compunit_symtab (obj_file, + msymbol, + pc, + section, + 0); + if (result != NULL) + return result; + } - if (BLOCK_START (b) <= pc - && BLOCK_END (b) > pc - && (distance == 0 - || BLOCK_END (b) - BLOCK_START (b) < distance)) + if (section != 0) { - /* For an objfile that has its functions reordered, - find_pc_psymtab will find the proper partial symbol table - and we simply return its corresponding symtab. */ - /* In order to better support objfiles that contain both - stabs and coff debugging info, we continue on if a psymtab - can't be found. */ - if ((obj_file->flags & OBJF_REORDERED) && obj_file->sf) + struct symbol *sym = NULL; + struct block_iterator iter; + + ALL_BLOCK_SYMBOLS (global_block, iter, sym) { - struct compunit_symtab *result; - - result - = obj_file->sf->qf->find_pc_sect_compunit_symtab (obj_file, - msymbol, - pc, - section, - 0); - if (result != NULL) - return result; + fixup_symbol_section (sym, obj_file); + if (matching_obj_sections (SYMBOL_OBJ_SECTION (obj_file, + sym), + section)) + break; } - if (section != 0) - { - struct block_iterator iter; - struct symbol *sym = NULL; - - ALL_BLOCK_SYMBOLS (b, iter, sym) - { - fixup_symbol_section (sym, obj_file); - if (matching_obj_sections (SYMBOL_OBJ_SECTION (obj_file, - sym), - section)) - break; - } - if (sym == NULL) - continue; /* No symbol in this symtab matches + if (sym == NULL) + continue; /* No symbol in this symtab matches section. */ - } - distance = BLOCK_END (b) - BLOCK_START (b); - best_cust = cust; } + + /* Cust is best found sofar, save it. */ + best_cust = cust; + best_cust_range = range; } } -- 2.26.2
Locations
Projects
Search
Status Monitor
Help
OpenBuildService.org
Documentation
API Documentation
Code of Conduct
Contact
Support
@OBShq
Terms
openSUSE Build Service is sponsored by
The Open Build Service is an
openSUSE project
.
Sign Up
Log In
Places
Places
All Projects
Status Monitor