diff options
author | Jim Kingdon <jkingdon@engr.sgi.com> | 1993-03-30 15:59:01 +0000 |
---|---|---|
committer | Jim Kingdon <jkingdon@engr.sgi.com> | 1993-03-30 15:59:01 +0000 |
commit | 0791c5ea6c388327cb59517c62cbec73831c5cbf (patch) | |
tree | 97533f0cb9a7e28db14bc5655875218ada777cb5 /gdb/findvar.c | |
parent | c0f1bbb6d0f63956f4c73514231fde9c5639d318 (diff) | |
download | gdb-0791c5ea6c388327cb59517c62cbec73831c5cbf.zip gdb-0791c5ea6c388327cb59517c62cbec73831c5cbf.tar.gz gdb-0791c5ea6c388327cb59517c62cbec73831c5cbf.tar.bz2 |
add comment
Diffstat (limited to 'gdb/findvar.c')
-rw-r--r-- | gdb/findvar.c | 196 |
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, ®isters[regbyte], len); + memcpy (myaddr, ®isters[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, ®isters[REGISTER_BYTE (regno)], - REGISTER_RAW_SIZE (regno)); + memcpy (myaddr, ®isters[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 (®isters[regbyte], myaddr, len); + memcpy (®isters[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 (®, ®isters[REGISTER_BYTE (regno)], sizeof (REGISTER_TYPE)); - SWAP_TARGET_AND_HOST (®, sizeof (REGISTER_TYPE)); - return reg; + + switch (REGISTER_RAW_SIZE(regno)) + { + case sizeof (unsigned char): + return registers[REGISTER_BYTE (regno)]; + case sizeof (sval): + memcpy (&sval, ®isters[REGISTER_BYTE (regno)], sizeof (sval)); + SWAP_TARGET_AND_HOST (&sval, sizeof (sval)); + return sval; + case sizeof (lval): + memcpy (&lval, ®isters[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 (®, sizeof (REGISTER_TYPE)); - target_prepare_to_store (); register_valid [regno] = 1; - memcpy (®isters[REGISTER_BYTE (regno)], ®, 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 (®isters[REGISTER_BYTE (regno)], &sval, sizeof (sval)); + break; + case sizeof (lval): + lval = val; + SWAP_TARGET_AND_HOST (&lval, sizeof (lval)); + memcpy (®isters[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 (®isters[REGISTER_BYTE (regno)], val, - REGISTER_RAW_SIZE (regno)); + memcpy (®isters[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, ®isters[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 */ |