gdb/
authorYao Qi <yao@codesourcery.com>
Tue, 27 Nov 2012 08:11:59 +0000 (08:11 +0000)
committerYao Qi <yao@codesourcery.com>
Tue, 27 Nov 2012 08:11:59 +0000 (08:11 +0000)
2012-11-27  Daniel Jacobowitz  <dan@codesourcery.com>
    Kazu Hirata  <kazu@codesourcery.com>
    Yao Qi  <yao@codesourcery.com>

* objfiles.c (init_entry_point_info): Call
gdbarch_convert_from_func_ptr_addr and
gdbarch_addr_bits_remove here ...
(entry_point_address_query): ... instead of here.
* solib-svr4.c (exec_entry_point): Call
gdbarch_addr_bits_remove.
* symfile.c (generic_load): Call gdbarch_addr_bits_remove on
the entry address.

gdb/ChangeLog
gdb/objfiles.c
gdb/solib-svr4.c
gdb/symfile.c

index 7030b8543fc8be44cb2e0020fd043353005d78da..0d8cad23aa1401a3088cf7970d5c97f5142b1a3d 100644 (file)
@@ -1,3 +1,16 @@
+2012-11-27  Daniel Jacobowitz  <dan@codesourcery.com>
+           Kazu Hirata  <kazu@codesourcery.com>
+           Yao Qi  <yao@codesourcery.com>
+
+       * objfiles.c (init_entry_point_info): Call
+       gdbarch_convert_from_func_ptr_addr and
+       gdbarch_addr_bits_remove here ...
+       (entry_point_address_query): ... instead of here.
+       * solib-svr4.c (exec_entry_point): Call
+       gdbarch_addr_bits_remove.
+       * symfile.c (generic_load): Call gdbarch_addr_bits_remove on
+       the entry address.
+
 2012-11-27  Daniel Jacobowitz  <dan@codesourcery.com>
            Yao Qi  <yao@codesourcery.com>
 
index 4cc2feab2de4b0fa100f0888ab3575f9554b362e..e5681fa7ade32c6a1cb3a26f43d3865d416c58fe 100644 (file)
@@ -353,6 +353,23 @@ init_entry_point_info (struct objfile *objfile)
       /* Examination of non-executable.o files.  Short-circuit this stuff.  */
       objfile->ei.entry_point_p = 0;
     }
+
+  if (objfile->ei.entry_point_p)
+    {
+      CORE_ADDR entry_point =  objfile->ei.entry_point;
+
+      /* Make certain that the address points at real code, and not a
+        function descriptor.  */
+      entry_point
+       = gdbarch_convert_from_func_ptr_addr (objfile->gdbarch,
+                                             entry_point,
+                                             &current_target);
+
+      /* Remove any ISA markers, so that this matches entries in the
+        symbol table.  */
+      objfile->ei.entry_point
+       = gdbarch_addr_bits_remove (objfile->gdbarch, entry_point);
+    }
 }
 
 /* If there is a valid and known entry point, function fills *ENTRY_P with it
@@ -361,26 +378,11 @@ init_entry_point_info (struct objfile *objfile)
 int
 entry_point_address_query (CORE_ADDR *entry_p)
 {
-  struct gdbarch *gdbarch;
-  CORE_ADDR entry_point;
-
   if (symfile_objfile == NULL || !symfile_objfile->ei.entry_point_p)
     return 0;
 
-  gdbarch = get_objfile_arch (symfile_objfile);
-
-  entry_point = symfile_objfile->ei.entry_point;
-
-  /* Make certain that the address points at real code, and not a
-     function descriptor.  */
-  entry_point = gdbarch_convert_from_func_ptr_addr (gdbarch, entry_point,
-                                                   &current_target);
-
-  /* Remove any ISA markers, so that this matches entries in the
-     symbol table.  */
-  entry_point = gdbarch_addr_bits_remove (gdbarch, entry_point);
+  *entry_p = symfile_objfile->ei.entry_point;
 
-  *entry_p = entry_point;
   return 1;
 }
 
index 37cc654dbdd58212f68bf25cc736d60e6ea53b35..02e45a352d63f9ff8e7dc771042a4bb84aaf67b1 100644 (file)
@@ -1388,6 +1388,8 @@ svr4_in_dynsym_resolve_code (CORE_ADDR pc)
 static CORE_ADDR
 exec_entry_point (struct bfd *abfd, struct target_ops *targ)
 {
+  CORE_ADDR addr;
+
   /* KevinB wrote ... for most targets, the address returned by
      bfd_get_start_address() is the entry point for the start
      function.  But, for some targets, bfd_get_start_address() returns
@@ -1396,9 +1398,10 @@ exec_entry_point (struct bfd *abfd, struct target_ops *targ)
      gdbarch_convert_from_func_ptr_addr().  The method
      gdbarch_convert_from_func_ptr_addr() is the merely the identify
      function for targets which don't use function descriptors.  */
-  return gdbarch_convert_from_func_ptr_addr (target_gdbarch (),
+  addr = gdbarch_convert_from_func_ptr_addr (target_gdbarch (),
                                             bfd_get_start_address (abfd),
                                             targ);
+  return gdbarch_addr_bits_remove (target_gdbarch (), addr);
 }
 
 /* Helper function for gdb_bfd_lookup_symbol.  */
index 6a2fc89e753a920487401cd81247954e304330f3..1d3278be083c8270c2d7cdc138f83f172a334968 100644 (file)
@@ -2150,6 +2150,7 @@ generic_load (char *args, int from_tty)
   gettimeofday (&end_time, NULL);
 
   entry = bfd_get_start_address (loadfile_bfd);
+  entry = gdbarch_addr_bits_remove (target_gdbarch (), entry);
   ui_out_text (uiout, "Start address ");
   ui_out_field_fmt (uiout, "address", "%s", paddress (target_gdbarch (), entry));
   ui_out_text (uiout, ", load size ");