aboutsummaryrefslogtreecommitdiff
path: root/gdb
diff options
context:
space:
mode:
authorMarkus Deuling <deuling@de.ibm.com>2007-11-21 06:02:53 +0000
committerMarkus Deuling <deuling@de.ibm.com>2007-11-21 06:02:53 +0000
commit123680036c40f8ed10bbdf9da800e71b48b3a4fc (patch)
tree92d684315d1e967d78dbb412a639966f2c211a3d /gdb
parentb9d9e222ea51ffa3c2a5139a58cbc59dce66a0c7 (diff)
downloadgdb-123680036c40f8ed10bbdf9da800e71b48b3a4fc.zip
gdb-123680036c40f8ed10bbdf9da800e71b48b3a4fc.tar.gz
gdb-123680036c40f8ed10bbdf9da800e71b48b3a4fc.tar.bz2
2007-11-21 Markus Deuling <deuling@de.ibm.com>
* stack.c (print_args_stub): Use get_frame_arch to get at the current architecture and replace current_gdbarch. (frame_info): Likewise.
Diffstat (limited to 'gdb')
-rw-r--r--gdb/ChangeLog6
-rw-r--r--gdb/stack.c12
2 files changed, 12 insertions, 6 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog
index 83f4108..97ba6ed 100644
--- a/gdb/ChangeLog
+++ b/gdb/ChangeLog
@@ -1,3 +1,9 @@
+2007-11-21 Markus Deuling <deuling@de.ibm.com>
+
+ * stack.c (print_args_stub): Use get_frame_arch to get at the current
+ architecture and replace current_gdbarch.
+ (frame_info): Likewise.
+
2007-11-21 Nick Roberts <nickrob@snap.net.nz>
* varobj.c (c_variable_editable, cplus_variable_editable)
diff --git a/gdb/stack.c b/gdb/stack.c
index 220a411..caf23a4 100644
--- a/gdb/stack.c
+++ b/gdb/stack.c
@@ -409,11 +409,12 @@ static int
print_args_stub (void *args)
{
struct print_args_args *p = args;
+ struct gdbarch *gdbarch = get_frame_arch (p->frame);
int numargs;
- if (gdbarch_frame_num_args_p (current_gdbarch))
+ if (gdbarch_frame_num_args_p (gdbarch))
{
- numargs = gdbarch_frame_num_args (current_gdbarch, p->frame);
+ numargs = gdbarch_frame_num_args (gdbarch, p->frame);
gdb_assert (numargs >= 0);
}
else
@@ -893,15 +894,15 @@ frame_info (char *addr_exp, int from_tty)
struct gdbarch *gdbarch;
fi = parse_frame_specification_1 (addr_exp, "No stack.", &selected_frame_p);
+ gdbarch = get_frame_arch (fi);
/* Name of the value returned by get_frame_pc(). Per comments, "pc"
is not a good name. */
- if (gdbarch_pc_regnum (current_gdbarch) >= 0)
+ if (gdbarch_pc_regnum (gdbarch) >= 0)
/* OK, this is weird. The gdbarch_pc_regnum hardware register's value can
easily not match that of the internal value returned by
get_frame_pc(). */
- pc_regname = gdbarch_register_name (current_gdbarch,
- gdbarch_pc_regnum (current_gdbarch));
+ pc_regname = gdbarch_register_name (gdbarch, gdbarch_pc_regnum (gdbarch));
else
/* But then, this is weird to. Even without gdbarch_pc_regnum, an
architectures will often have a hardware register called "pc",
@@ -910,7 +911,6 @@ frame_info (char *addr_exp, int from_tty)
pc_regname = "pc";
find_frame_sal (fi, &sal);
- gdbarch = get_frame_arch (fi);
func = get_frame_function (fi);
/* FIXME: cagney/2002-11-28: Why bother? Won't sal.symtab contain
the same value? */