From 14e534aa3559f269c92d72f1d9a5dda56c0aab2d Mon Sep 17 00:00:00 2001 From: Pierre Muller Date: Mon, 3 Dec 2001 08:41:10 +0000 Subject: [PATCH] 2001-11-30 Pierre Muller * findvar.c (locate_var_value): Specify in which register a register variable is stored. --- gdb/ChangeLog | 5 +++++ gdb/findvar.c | 17 +++++++++++++++-- 2 files changed, 20 insertions(+), 2 deletions(-) diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 3cdd070244..732be2559d 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,8 @@ +2001-11-30 Pierre Muller + + * findvar.c (locate_var_value): Specify in which register a register + variable is stored. + 2001-11-30 Pierre Muller * win32-nat.c (mappings): Correct position of XMM registers, diff --git a/gdb/findvar.c b/gdb/findvar.c index b9b9be47b3..5f5766cac3 100644 --- a/gdb/findvar.c +++ b/gdb/findvar.c @@ -29,6 +29,7 @@ #include "inferior.h" #include "target.h" #include "gdb_string.h" +#include "gdb_assert.h" #include "floatformat.h" #include "symfile.h" /* for overlay functions */ #include "regcache.h" @@ -869,9 +870,21 @@ locate_var_value (register struct symbol *var, struct frame_info *frame) switch (VALUE_LVAL (lazy_value)) { case lval_register: + gdb_assert (REGISTER_NAME (VALUE_REGNO (lazy_value)) != NULL + && *REGISTER_NAME (VALUE_REGNO (lazy_value)) != '\0'); + error("Address requested for identifier " + "\"%s\" which is in register $%s", + SYMBOL_SOURCE_NAME (var), + REGISTER_NAME (VALUE_REGNO (lazy_value))); + break; + case lval_reg_frame_relative: - error ("Address requested for identifier \"%s\" which is in a register.", - SYMBOL_SOURCE_NAME (var)); + gdb_assert (REGISTER_NAME (VALUE_FRAME_REGNUM (lazy_value)) != NULL + && *REGISTER_NAME (VALUE_FRAME_REGNUM (lazy_value)) != '\0'); + error("Address requested for identifier " + "\"%s\" which is in frame register $%s", + SYMBOL_SOURCE_NAME (var), + REGISTER_NAME (VALUE_FRAME_REGNUM (lazy_value))); break; default: