aboutsummaryrefslogtreecommitdiff
path: root/gdb/findvar.c
diff options
context:
space:
mode:
authorJim Kingdon <jkingdon@engr.sgi.com>1993-03-30 15:59:01 +0000
committerJim Kingdon <jkingdon@engr.sgi.com>1993-03-30 15:59:01 +0000
commit0791c5ea6c388327cb59517c62cbec73831c5cbf (patch)
tree97533f0cb9a7e28db14bc5655875218ada777cb5 /gdb/findvar.c
parentc0f1bbb6d0f63956f4c73514231fde9c5639d318 (diff)
downloadgdb-0791c5ea6c388327cb59517c62cbec73831c5cbf.zip
gdb-0791c5ea6c388327cb59517c62cbec73831c5cbf.tar.gz
gdb-0791c5ea6c388327cb59517c62cbec73831c5cbf.tar.bz2
add comment
Diffstat (limited to 'gdb/findvar.c')
-rw-r--r--gdb/findvar.c196
1 files changed, 149 insertions, 47 deletions
diff --git a/gdb/findvar.c b/gdb/findvar.c
index 3563c58..33f5ad6 100644
--- a/gdb/findvar.c
+++ b/gdb/findvar.c
@@ -171,8 +171,7 @@ read_relative_register_raw_bytes (regnum, myaddr)
int optim;
if (regnum == FP_REGNUM && selected_frame)
{
- (void) memcpy (myaddr, &FRAME_FP(selected_frame),
- REGISTER_RAW_SIZE(FP_REGNUM));
+ memcpy (myaddr, &FRAME_FP(selected_frame), REGISTER_RAW_SIZE(FP_REGNUM));
SWAP_TARGET_AND_HOST (myaddr, REGISTER_RAW_SIZE(FP_REGNUM)); /* in target order */
return 0;
}
@@ -200,10 +199,10 @@ value_of_register (regnum)
get_saved_register (raw_buffer, &optim, &addr,
selected_frame, regnum, &lval);
- target_convert_to_virtual (regnum, raw_buffer, virtual_buffer);
+ REGISTER_CONVERT_TO_VIRTUAL (regnum, raw_buffer, virtual_buffer);
val = allocate_value (REGISTER_VIRTUAL_TYPE (regnum));
- (void) memcpy (VALUE_CONTENTS_RAW (val), virtual_buffer,
- REGISTER_VIRTUAL_SIZE (regnum));
+ memcpy (VALUE_CONTENTS_RAW (val), virtual_buffer,
+ REGISTER_VIRTUAL_SIZE (regnum));
VALUE_LVAL (val) = lval;
VALUE_ADDRESS (val) = addr;
VALUE_REGNO (val) = regnum;
@@ -263,7 +262,7 @@ read_register_bytes (regbyte, myaddr, len)
break;
}
if (myaddr != NULL)
- (void) memcpy (myaddr, &registers[regbyte], len);
+ memcpy (myaddr, &registers[regbyte], len);
}
/* Read register REGNO into memory at MYADDR, which must be large enough
@@ -277,8 +276,8 @@ read_register_gen (regno, myaddr)
{
if (!register_valid[regno])
target_fetch_registers (regno);
- (void) memcpy (myaddr, &registers[REGISTER_BYTE (regno)],
- REGISTER_RAW_SIZE (regno));
+ memcpy (myaddr, &registers[REGISTER_BYTE (regno)],
+ REGISTER_RAW_SIZE (regno));
}
/* Copy LEN bytes of consecutive data from memory at MYADDR
@@ -292,7 +291,7 @@ write_register_bytes (regbyte, myaddr, len)
{
/* Make sure the entire registers array is valid. */
read_register_bytes (0, (char *)NULL, REGISTER_BYTES);
- (void) memcpy (&registers[regbyte], myaddr, len);
+ memcpy (&registers[regbyte], myaddr, len);
target_store_registers (-1);
}
@@ -304,13 +303,28 @@ CORE_ADDR
read_register (regno)
int regno;
{
- REGISTER_TYPE reg;
+ unsigned short sval;
+ unsigned long lval;
if (!register_valid[regno])
target_fetch_registers (regno);
- memcpy (&reg, &registers[REGISTER_BYTE (regno)], sizeof (REGISTER_TYPE));
- SWAP_TARGET_AND_HOST (&reg, sizeof (REGISTER_TYPE));
- return reg;
+
+ switch (REGISTER_RAW_SIZE(regno))
+ {
+ case sizeof (unsigned char):
+ return registers[REGISTER_BYTE (regno)];
+ case sizeof (sval):
+ memcpy (&sval, &registers[REGISTER_BYTE (regno)], sizeof (sval));
+ SWAP_TARGET_AND_HOST (&sval, sizeof (sval));
+ return sval;
+ case sizeof (lval):
+ memcpy (&lval, &registers[REGISTER_BYTE (regno)], sizeof (lval));
+ SWAP_TARGET_AND_HOST (&lval, sizeof (lval));
+ return lval;
+ default:
+ error ("Can't handle register size of %d for register %d\n",
+ REGISTER_RAW_SIZE(regno), regno);
+ }
}
/* Registers we shouldn't try to store. */
@@ -326,20 +340,34 @@ void
write_register (regno, val)
int regno, val;
{
- REGISTER_TYPE reg;
+ unsigned short sval;
+ unsigned long lval;
/* On the sparc, writing %g0 is a no-op, so we don't even want to change
the registers array if something writes to this register. */
if (CANNOT_STORE_REGISTER (regno))
return;
- reg = val;
- SWAP_TARGET_AND_HOST (&reg, sizeof (REGISTER_TYPE));
-
target_prepare_to_store ();
register_valid [regno] = 1;
- memcpy (&registers[REGISTER_BYTE (regno)], &reg, sizeof (REGISTER_TYPE));
+
+ switch (REGISTER_RAW_SIZE(regno))
+ {
+ case sizeof (unsigned char):
+ registers[REGISTER_BYTE (regno)] = val;
+ break;
+ case sizeof (sval):
+ sval = val;
+ SWAP_TARGET_AND_HOST (&sval, sizeof (sval));
+ memcpy (&registers[REGISTER_BYTE (regno)], &sval, sizeof (sval));
+ break;
+ case sizeof (lval):
+ lval = val;
+ SWAP_TARGET_AND_HOST (&lval, sizeof (lval));
+ memcpy (&registers[REGISTER_BYTE (regno)], &lval, sizeof (lval));
+ break;
+ }
target_store_registers (regno);
}
@@ -354,8 +382,13 @@ supply_register (regno, val)
char *val;
{
register_valid[regno] = 1;
- (void) memcpy (&registers[REGISTER_BYTE (regno)], val,
- REGISTER_RAW_SIZE (regno));
+ memcpy (&registers[REGISTER_BYTE (regno)], val, REGISTER_RAW_SIZE (regno));
+
+ /* On some architectures, e.g. HPPA, there are a few stray bits in some
+ registers, that the rest of the code would like to ignore. */
+#ifdef CLEAN_UP_REGISTER_VALUE
+ CLEAN_UP_REGISTER_VALUE(regno, &registers[REGISTER_BYTE(regno)]);
+#endif
}
/* Given a struct symbol for a variable,
@@ -384,14 +417,14 @@ read_var_value (var, frame)
switch (SYMBOL_CLASS (var))
{
case LOC_CONST:
- (void) memcpy (VALUE_CONTENTS_RAW (v), &SYMBOL_VALUE (var), len);
+ memcpy (VALUE_CONTENTS_RAW (v), &SYMBOL_VALUE (var), len);
SWAP_TARGET_AND_HOST (VALUE_CONTENTS_RAW (v), len);
VALUE_LVAL (v) = not_lval;
return v;
case LOC_LABEL:
addr = SYMBOL_VALUE_ADDRESS (var);
- (void) memcpy (VALUE_CONTENTS_RAW (v), &addr, len);
+ memcpy (VALUE_CONTENTS_RAW (v), &addr, len);
SWAP_TARGET_AND_HOST (VALUE_CONTENTS_RAW (v), len);
VALUE_LVAL (v) = not_lval;
return v;
@@ -400,7 +433,7 @@ read_var_value (var, frame)
{
char *bytes_addr;
bytes_addr = SYMBOL_VALUE_BYTES (var);
- (void) memcpy (VALUE_CONTENTS_RAW (v), bytes_addr, len);
+ memcpy (VALUE_CONTENTS_RAW (v), bytes_addr, len);
VALUE_LVAL (v) = not_lval;
return v;
}
@@ -487,6 +520,9 @@ read_var_value (var, frame)
really contains
the address of the struct, not the struct itself. GCC_P is nonzero
if the function was compiled with GCC. */
+ /* A cleaner way to do this would be to add LOC_REGISTER_ADDR
+ (register contains the address of the value) and LOC_REGPARM_ADDR,
+ and have the symbol-reading code set them -kingdon. */
#if !defined (REG_STRUCT_HAS_ADDR)
#define REG_STRUCT_HAS_ADDR(gcc_p) 0
#endif
@@ -494,7 +530,10 @@ read_var_value (var, frame)
if (REG_STRUCT_HAS_ADDR (BLOCK_GCC_COMPILED (b))
&& ( (TYPE_CODE (type) == TYPE_CODE_STRUCT)
|| (TYPE_CODE (type) == TYPE_CODE_UNION)))
- addr = *(CORE_ADDR *)VALUE_CONTENTS (v);
+ {
+ addr = *(CORE_ADDR *)VALUE_CONTENTS (v);
+ VALUE_LVAL (v) = lval_memory;
+ }
else
return v;
}
@@ -536,7 +575,11 @@ value_from_register (type, regnum, frame)
((len - 1) / REGISTER_RAW_SIZE (regnum)) + 1 :
1);
- if (num_storage_locs > 1)
+ if (num_storage_locs > 1
+#ifdef GDB_TARGET_IS_H8500
+ || TYPE_CODE (type) == TYPE_CODE_PTR
+#endif
+ )
{
/* Value spread across multiple storage locations. */
@@ -550,33 +593,93 @@ value_from_register (type, regnum, frame)
/* Copy all of the data out, whereever it may be. */
- for (local_regnum = regnum;
- value_bytes_copied < len;
- (value_bytes_copied += REGISTER_RAW_SIZE (local_regnum),
- ++local_regnum))
+#ifdef GDB_TARGET_IS_H8500
+/* This piece of hideosity is required because the H8500 treats registers
+ differently depending upon whether they are used as pointers or not. As a
+ pointer, a register needs to have a page register tacked onto the front.
+ An alternate way to do this would be to have gcc output different register
+ numbers for the pointer & non-pointer form of the register. But, it
+ doesn't, so we're stuck with this. */
+
+ if (TYPE_CODE (type) == TYPE_CODE_PTR)
{
- get_saved_register (value_bytes + value_bytes_copied,
+ int page_regnum;
+
+ switch (regnum)
+ {
+ case R0_REGNUM: case R1_REGNUM: case R2_REGNUM: case R3_REGNUM:
+ page_regnum = SEG_D_REGNUM;
+ break;
+ case R4_REGNUM: case R5_REGNUM:
+ page_regnum = SEG_E_REGNUM;
+ break;
+ case R6_REGNUM: case R7_REGNUM:
+ page_regnum = SEG_T_REGNUM;
+ break;
+ }
+
+ value_bytes[0] = 0;
+ get_saved_register (value_bytes + 1,
&optim,
&addr,
frame,
- local_regnum,
+ page_regnum,
&lval);
+
if (lval == lval_register)
reg_stor++;
else
{
mem_stor++;
+ first_addr = addr;
+ }
+ last_addr = addr;
- if (regnum == local_regnum)
- first_addr = addr;
-
- mem_tracking =
- (mem_tracking
- && (regnum == local_regnum
- || addr == last_addr));
+ get_saved_register (value_bytes + 2,
+ &optim,
+ &addr,
+ frame,
+ regnum,
+ &lval);
+
+ if (lval == lval_register)
+ reg_stor++;
+ else
+ {
+ mem_stor++;
+ mem_tracking = mem_tracking && (addr == last_addr);
}
last_addr = addr;
}
+ else
+#endif /* GDB_TARGET_IS_H8500 */
+ for (local_regnum = regnum;
+ value_bytes_copied < len;
+ (value_bytes_copied += REGISTER_RAW_SIZE (local_regnum),
+ ++local_regnum))
+ {
+ get_saved_register (value_bytes + value_bytes_copied,
+ &optim,
+ &addr,
+ frame,
+ local_regnum,
+ &lval);
+ if (lval == lval_register)
+ reg_stor++;
+ else
+ {
+ mem_stor++;
+
+ if (regnum == local_regnum)
+ first_addr = addr;
+
+ mem_tracking =
+ (mem_tracking
+ && (regnum == local_regnum
+ || addr == last_addr));
+ }
+ last_addr = addr;
+ }
if ((reg_stor && mem_stor)
|| (mem_stor && !mem_tracking))
@@ -608,7 +711,7 @@ value_from_register (type, regnum, frame)
endian machines. */
/* Copy into the contents section of the value. */
- (void) memcpy (VALUE_CONTENTS_RAW (v), value_bytes, len);
+ memcpy (VALUE_CONTENTS_RAW (v), value_bytes, len);
return v;
}
@@ -625,7 +728,7 @@ value_from_register (type, regnum, frame)
/* Convert the raw contents to virtual contents.
(Just copy them if the formats are the same.) */
- target_convert_to_virtual (regnum, raw_buffer, virtual_buffer);
+ REGISTER_CONVERT_TO_VIRTUAL (regnum, raw_buffer, virtual_buffer);
if (REGISTER_CONVERTIBLE (regnum))
{
@@ -640,11 +743,11 @@ value_from_register (type, regnum, frame)
with raw type `extended' and virtual type `double'.
Fetch it as a `double' and then convert to `float'. */
v = allocate_value (REGISTER_VIRTUAL_TYPE (regnum));
- (void) memcpy (VALUE_CONTENTS_RAW (v), virtual_buffer, len);
+ memcpy (VALUE_CONTENTS_RAW (v), virtual_buffer, len);
v = value_cast (type, v);
}
else
- (void) memcpy (VALUE_CONTENTS_RAW (v), virtual_buffer, len);
+ memcpy (VALUE_CONTENTS_RAW (v), virtual_buffer, len);
}
else
{
@@ -658,8 +761,7 @@ value_from_register (type, regnum, frame)
}
#endif
- (void) memcpy (VALUE_CONTENTS_RAW (v), virtual_buffer + VALUE_OFFSET (v),
- len);
+ memcpy (VALUE_CONTENTS_RAW (v), virtual_buffer + VALUE_OFFSET (v), len);
}
return v;
@@ -684,7 +786,7 @@ locate_var_value (var, frame)
lazy_value = read_var_value (var, frame);
if (lazy_value == 0)
- error ("Address of \"%s\" is unknown.", SYMBOL_NAME (var));
+ error ("Address of \"%s\" is unknown.", SYMBOL_SOURCE_NAME (var));
if (VALUE_LAZY (lazy_value)
|| TYPE_CODE (type) == TYPE_CODE_FUNC)
@@ -699,12 +801,12 @@ locate_var_value (var, frame)
case lval_register:
case lval_reg_frame_relative:
error ("Address requested for identifier \"%s\" which is in a register.",
- SYMBOL_NAME (var));
+ SYMBOL_SOURCE_NAME (var));
break;
default:
error ("Can't take address of \"%s\" which isn't an lvalue.",
- SYMBOL_NAME (var));
+ SYMBOL_SOURCE_NAME (var));
break;
}
return 0; /* For lint -- never reached */