PR c++/1267
authorDaniel Jacobowitz <drow@false.org>
Sat, 26 Jul 2003 22:03:38 +0000 (22:03 +0000)
committerDaniel Jacobowitz <drow@false.org>
Sat, 26 Jul 2003 22:03:38 +0000 (22:03 +0000)
* minsyms.c (lookup_minimal_symbol_by_pc_section): If SECTION is
NULL, default to the section containing PC.

gdb/ChangeLog
gdb/minsyms.c

index 6473f3e9b3a516ceba197da9bc35553dc3292dff..60e60f9cf3cb324a2ff69a4e59d92305fc1d6be3 100644 (file)
@@ -1,3 +1,9 @@
+2003-07-26  Daniel Jacobowitz  <drow@mvista.com>
+
+       PR c++/1267
+       * minsyms.c (lookup_minimal_symbol_by_pc_section): If SECTION is
+       NULL, default to the section containing PC.
+
 2003-07-24  Stephane Carrez  <stcarrez@nerim.fr>
 
        * NEWS: Mention "regs" deprecated for m68hc11 too.
index fa7209d2bc633d9756a62ca0753a365461668c19..319865f6faf52a6689c69345627c9a3beadc3775 100644 (file)
@@ -403,13 +403,23 @@ lookup_minimal_symbol_by_pc_section (CORE_ADDR pc, asection *section)
   struct objfile *objfile;
   struct minimal_symbol *msymbol;
   struct minimal_symbol *best_symbol = NULL;
+  struct obj_section *pc_section;
 
   /* pc has to be in a known section. This ensures that anything beyond
      the end of the last segment doesn't appear to be part of the last
      function in the last segment.  */
-  if (find_pc_section (pc) == NULL)
+  pc_section = find_pc_section (pc);
+  if (pc_section == NULL)
     return NULL;
 
+  /* If no section was specified, then just make sure that the PC is in
+     the same section as the minimal symbol we find.  */
+  if (section == NULL)
+    section = pc_section->the_bfd_section;
+
+  /* FIXME drow/2003-07-19: Should we also check that PC is in SECTION
+     if we were passed a non-NULL SECTION argument?  */
+
   for (objfile = object_files;
        objfile != NULL;
        objfile = objfile->next)