2003-06-01 Andrew Cagney <cagney@redhat.com>

* defs.h (extract_address): Delete declaration.
	* findvar.c (extract_address): Delete function.
	* xstormy16-tdep.c (xstormy16_extract_return_value): Replace
	extract_address with the inline equivalent,
	extract_unsigned_integer.
	(xstormy16_extract_struct_value_address): Ditto.
	(xstormy16_pointer_to_address): Ditto.
	* vax-tdep.c (vax_extract_struct_value_address): Ditto.
	* v850-tdep.c (v850_push_arguments): Ditto.
	(v850_extract_return_value): Ditto.
	(v850_extract_struct_value_address): Ditto.
	* sparcnbsd-tdep.c (sparcnbsd_get_longjmp_target_32): Ditto.
	(sparcnbsd_get_longjmp_target_64): Ditto.
	* sparc-tdep.c (sparc_frame_saved_pc): Ditto.
	(get_longjmp_target): Ditto.
	* sh-tdep.c (sh_extract_struct_value_address): Ditto.
	(sh64_extract_struct_value_address): Ditto.
	(sh_push_arguments): Ditto.
	(sh64_push_arguments): Ditto.
	* remote-vxsparc.c (vx_read_register): Ditto.
	* ppc-linux-tdep.c (ppc_linux_skip_trampoline_code): Ditto.
	* ns32k-tdep.c (ns32k_extract_struct_value_address): Ditto.
	* mn10300-tdep.c (mn10300_extract_struct_value_address): Ditto.
	* mipsv4-nat.c (get_longjmp_target): Ditto.
	* mipsnbsd-tdep.c (mipsnbsd_get_longjmp_target): Ditto.
	* mips-nat.c (get_longjmp_target): Ditto.
	* mips-linux-tdep.c (mips_linux_get_longjmp_target): Ditto.
	* mcore-tdep.c (mcore_extract_struct_value_address): Ditto.
	* m68k-tdep.c (m68k_get_longjmp_target): Ditto.
	* m68hc11-tdep.c (m68hc11_extract_struct_value_address): Ditto.
	* irix5-nat.c (get_longjmp_target): Ditto.
	* irix4-nat.c (get_longjmp_target): Ditto.
	* ia64-tdep.c (generic_elf_find_global_pointer): Ditto.
	(ia64_push_arguments): Ditto.
	* hpux-thread.c (hpux_thread_store_registers): Ditto.
	* h8300-tdep.c (h8300_push_arguments): Ditto.
	(h8300_store_return_value): Ditto.
	(h8300_extract_struct_value_address): Ditto.
	* frv-tdep.c (frv_extract_struct_value_address): Ditto.
	(frv_push_arguments): Ditto.
	* avr-tdep.c (avr_pointer_to_address): Ditto.
	(avr_push_arguments): Ditto.
	* arm-tdep.c (arm_push_dummy_call): Ditto.
	(arm_get_longjmp_target): Ditto.
	* arm-linux-tdep.c (arm_linux_push_arguments): Ditto.
	* alpha-tdep.c (alpha_extract_struct_value_address): Ditto.
	(alpha_get_longjmp_target): Ditto.
This commit is contained in:
Andrew Cagney 2003-06-02 02:09:40 +00:00
parent 12be538b0b
commit 7c0b4a2066
30 changed files with 112 additions and 88 deletions

View file

@ -1,5 +1,53 @@
2003-06-01 Andrew Cagney <cagney@redhat.com> 2003-06-01 Andrew Cagney <cagney@redhat.com>
* defs.h (extract_address): Delete declaration.
* findvar.c (extract_address): Delete function.
* xstormy16-tdep.c (xstormy16_extract_return_value): Replace
extract_address with the inline equivalent,
extract_unsigned_integer.
(xstormy16_extract_struct_value_address): Ditto.
(xstormy16_pointer_to_address): Ditto.
* vax-tdep.c (vax_extract_struct_value_address): Ditto.
* v850-tdep.c (v850_push_arguments): Ditto.
(v850_extract_return_value): Ditto.
(v850_extract_struct_value_address): Ditto.
* sparcnbsd-tdep.c (sparcnbsd_get_longjmp_target_32): Ditto.
(sparcnbsd_get_longjmp_target_64): Ditto.
* sparc-tdep.c (sparc_frame_saved_pc): Ditto.
(get_longjmp_target): Ditto.
* sh-tdep.c (sh_extract_struct_value_address): Ditto.
(sh64_extract_struct_value_address): Ditto.
(sh_push_arguments): Ditto.
(sh64_push_arguments): Ditto.
* remote-vxsparc.c (vx_read_register): Ditto.
* ppc-linux-tdep.c (ppc_linux_skip_trampoline_code): Ditto.
* ns32k-tdep.c (ns32k_extract_struct_value_address): Ditto.
* mn10300-tdep.c (mn10300_extract_struct_value_address): Ditto.
* mipsv4-nat.c (get_longjmp_target): Ditto.
* mipsnbsd-tdep.c (mipsnbsd_get_longjmp_target): Ditto.
* mips-nat.c (get_longjmp_target): Ditto.
* mips-linux-tdep.c (mips_linux_get_longjmp_target): Ditto.
* mcore-tdep.c (mcore_extract_struct_value_address): Ditto.
* m68k-tdep.c (m68k_get_longjmp_target): Ditto.
* m68hc11-tdep.c (m68hc11_extract_struct_value_address): Ditto.
* irix5-nat.c (get_longjmp_target): Ditto.
* irix4-nat.c (get_longjmp_target): Ditto.
* ia64-tdep.c (generic_elf_find_global_pointer): Ditto.
(ia64_push_arguments): Ditto.
* hpux-thread.c (hpux_thread_store_registers): Ditto.
* h8300-tdep.c (h8300_push_arguments): Ditto.
(h8300_store_return_value): Ditto.
(h8300_extract_struct_value_address): Ditto.
* frv-tdep.c (frv_extract_struct_value_address): Ditto.
(frv_push_arguments): Ditto.
* avr-tdep.c (avr_pointer_to_address): Ditto.
(avr_push_arguments): Ditto.
* arm-tdep.c (arm_push_dummy_call): Ditto.
(arm_get_longjmp_target): Ditto.
* arm-linux-tdep.c (arm_linux_push_arguments): Ditto.
* alpha-tdep.c (alpha_extract_struct_value_address): Ditto.
(alpha_get_longjmp_target): Ditto.
* solib-irix.c (extract_mips_address): Inline extract_address, * solib-irix.c (extract_mips_address): Inline extract_address,
replacing it with extract_signed_integer. replacing it with extract_signed_integer.
* solib-svr4.c (SOLIB_EXTRACT_ADDRESS): Ditto. * solib-svr4.c (SOLIB_EXTRACT_ADDRESS): Ditto.

View file

@ -381,8 +381,8 @@ alpha_store_struct_return (CORE_ADDR addr, CORE_ADDR sp)
static CORE_ADDR static CORE_ADDR
alpha_extract_struct_value_address (char *regbuf) alpha_extract_struct_value_address (char *regbuf)
{ {
return (extract_address (regbuf + REGISTER_BYTE (ALPHA_V0_REGNUM), return (extract_unsigned_integer (regbuf + REGISTER_BYTE (ALPHA_V0_REGNUM),
REGISTER_RAW_SIZE (ALPHA_V0_REGNUM))); REGISTER_RAW_SIZE (ALPHA_V0_REGNUM)));
} }
@ -518,7 +518,7 @@ alpha_get_longjmp_target (CORE_ADDR *pc)
raw_buffer, tdep->jb_elt_size)) raw_buffer, tdep->jb_elt_size))
return 0; return 0;
*pc = extract_address (raw_buffer, tdep->jb_elt_size); *pc = extract_unsigned_integer (raw_buffer, tdep->jb_elt_size);
return 1; return 1;
} }

View file

@ -193,7 +193,7 @@ arm_linux_push_arguments (int nargs, struct value **args, CORE_ADDR sp,
&& NULL != target_type && NULL != target_type
&& TYPE_CODE_FUNC == TYPE_CODE (target_type)) && TYPE_CODE_FUNC == TYPE_CODE (target_type))
{ {
CORE_ADDR regval = extract_address (val, len); CORE_ADDR regval = extract_unsigned_integer (val, len);
if (arm_pc_is_thumb (regval)) if (arm_pc_is_thumb (regval))
store_unsigned_integer (val, len, MAKE_THUMB_ADDR (regval)); store_unsigned_integer (val, len, MAKE_THUMB_ADDR (regval));
} }
@ -208,7 +208,7 @@ arm_linux_push_arguments (int nargs, struct value **args, CORE_ADDR sp,
if (argreg <= ARM_LAST_ARG_REGNUM) if (argreg <= ARM_LAST_ARG_REGNUM)
{ {
/* It's an argument being passed in a general register. */ /* It's an argument being passed in a general register. */
regval = extract_address (val, partial_len); regval = extract_unsigned_integer (val, partial_len);
write_register (argreg++, regval); write_register (argreg++, regval);
} }
else else

View file

@ -1465,7 +1465,7 @@ arm_push_dummy_call (struct gdbarch *gdbarch, CORE_ADDR func_addr,
&& target_type != NULL && target_type != NULL
&& TYPE_CODE_FUNC == TYPE_CODE (target_type)) && TYPE_CODE_FUNC == TYPE_CODE (target_type))
{ {
CORE_ADDR regval = extract_address (val, len); CORE_ADDR regval = extract_unsigned_integer (val, len);
if (arm_pc_is_thumb (regval)) if (arm_pc_is_thumb (regval))
{ {
val = alloca (len); val = alloca (len);
@ -1484,7 +1484,7 @@ arm_push_dummy_call (struct gdbarch *gdbarch, CORE_ADDR func_addr,
{ {
/* The argument is being passed in a general purpose /* The argument is being passed in a general purpose
register. */ register. */
CORE_ADDR regval = extract_address (val, partial_len); CORE_ADDR regval = extract_unsigned_integer (val, partial_len);
if (arm_debug) if (arm_debug)
fprintf_unfiltered (gdb_stdlog, "arg %d in %s = 0x%s\n", fprintf_unfiltered (gdb_stdlog, "arg %d in %s = 0x%s\n",
argnum, REGISTER_NAME (argreg), argnum, REGISTER_NAME (argreg),
@ -2494,7 +2494,7 @@ arm_get_longjmp_target (CORE_ADDR *pc)
INT_REGISTER_RAW_SIZE)) INT_REGISTER_RAW_SIZE))
return 0; return 0;
*pc = extract_address (buf, INT_REGISTER_RAW_SIZE); *pc = extract_unsigned_integer (buf, INT_REGISTER_RAW_SIZE);
return 1; return 1;
} }

View file

@ -324,7 +324,7 @@ avr_address_to_pointer (struct type *type, void *buf, CORE_ADDR addr)
static CORE_ADDR static CORE_ADDR
avr_pointer_to_address (struct type *type, const void *buf) avr_pointer_to_address (struct type *type, const void *buf)
{ {
CORE_ADDR addr = extract_address (buf, TYPE_LENGTH (type)); CORE_ADDR addr = extract_unsigned_integer (buf, TYPE_LENGTH (type));
if (TYPE_CODE_SPACE (TYPE_TARGET_TYPE (type))) if (TYPE_CODE_SPACE (TYPE_TARGET_TYPE (type)))
{ {
@ -1084,7 +1084,7 @@ avr_push_arguments (int nargs, struct value **args, CORE_ADDR sp,
while (len > 0) while (len > 0)
{ /* there's room in registers */ { /* there's room in registers */
len -= wordsize; len -= wordsize;
regval = extract_address (val + len, wordsize); regval = extract_unsigned_integer (val + len, wordsize);
write_register (argreg--, regval); write_register (argreg--, regval);
} }
} }

View file

@ -1126,8 +1126,6 @@ extern ULONGEST extract_unsigned_integer (const void *, int);
extern int extract_long_unsigned_integer (const void *, int, LONGEST *); extern int extract_long_unsigned_integer (const void *, int, LONGEST *);
extern CORE_ADDR extract_address (const void *, int);
extern CORE_ADDR extract_typed_address (const void *buf, struct type *type); extern CORE_ADDR extract_typed_address (const void *buf, struct type *type);
extern void store_signed_integer (void *, int, LONGEST); extern void store_signed_integer (void *, int, LONGEST);

View file

@ -161,28 +161,6 @@ extract_long_unsigned_integer (const void *addr, int orig_len, LONGEST *pval)
} }
/* Treat the LEN bytes at ADDR as a target-format address, and return
that address. ADDR is a buffer in the GDB process, not in the
inferior.
This function should only be used by target-specific code. It
assumes that a pointer has the same representation as that thing's
address represented as an integer. Some machines use word
addresses, or similarly munged things, for certain types of
pointers, so that assumption doesn't hold everywhere.
Common code should use extract_typed_address instead, or something
else based on POINTER_TO_ADDRESS. */
CORE_ADDR
extract_address (const void *addr, int len)
{
/* Assume a CORE_ADDR can fit in a LONGEST (for now). Not sure
whether we want this to be true eventually. */
return (CORE_ADDR) extract_unsigned_integer (addr, len);
}
/* Treat the bytes at BUF as a pointer of type TYPE, and return the /* Treat the bytes at BUF as a pointer of type TYPE, and return the
address it represents. */ address it represents. */
CORE_ADDR CORE_ADDR

View file

@ -762,8 +762,8 @@ frv_extract_return_value (struct type *type, char *regbuf, char *valbuf)
static CORE_ADDR static CORE_ADDR
frv_extract_struct_value_address (char *regbuf) frv_extract_struct_value_address (char *regbuf)
{ {
return extract_address (regbuf + frv_register_byte (struct_return_regnum), return extract_unsigned_integer (regbuf + frv_register_byte (struct_return_regnum),
4); 4);
} }
static void static void
@ -859,7 +859,7 @@ frv_push_arguments (int nargs, struct value **args, CORE_ADDR sp,
if (argreg < 14) if (argreg < 14)
{ {
regval = extract_address (val, partial_len); regval = extract_unsigned_integer (val, partial_len);
#if 0 #if 0
printf(" Argnum %d data %x -> reg %d\n", printf(" Argnum %d data %x -> reg %d\n",
argnum, (int) regval, argreg); argnum, (int) regval, argreg);

View file

@ -706,7 +706,7 @@ h8300_push_arguments (int nargs, struct value **args, CORE_ADDR sp,
for (offset = 0; offset < padded_len; offset += wordsize) for (offset = 0; offset < padded_len; offset += wordsize)
{ {
ULONGEST word = extract_address (padded + offset, wordsize); ULONGEST word = extract_unsigned_integer (padded + offset, wordsize);
write_register (reg++, word); write_register (reg++, word);
} }
} }
@ -830,11 +830,11 @@ h8300_store_return_value (struct type *type, char *valbuf)
{ {
case 1: /* char */ case 1: /* char */
case 2: /* short, int */ case 2: /* short, int */
regval = extract_address (valbuf, len); regval = extract_unsigned_integer (valbuf, len);
write_register (0, regval); write_register (0, regval);
break; break;
case 4: /* long, float */ case 4: /* long, float */
regval = extract_address (valbuf, len); regval = extract_unsigned_integer (valbuf, len);
if (wordsize == 4) if (wordsize == 4)
{ {
write_register (0, regval); write_register (0, regval);
@ -1032,8 +1032,8 @@ h8300_use_struct_convention (int gcc_p, struct type *type)
static CORE_ADDR static CORE_ADDR
h8300_extract_struct_value_address (char *regbuf) h8300_extract_struct_value_address (char *regbuf)
{ {
return extract_address (regbuf + h8300_register_byte (E_ARG0_REGNUM), return extract_unsigned_integer (regbuf + h8300_register_byte (E_ARG0_REGNUM),
h8300_register_raw_size (E_ARG0_REGNUM)); h8300_register_raw_size (E_ARG0_REGNUM));
} }
const static unsigned char * const static unsigned char *

View file

@ -360,8 +360,8 @@ hpux_thread_store_registers (int regno)
&deprecated_registers[REGISTER_BYTE (regno)], &deprecated_registers[REGISTER_BYTE (regno)],
REGISTER_RAW_SIZE (regno)); REGISTER_RAW_SIZE (regno));
tcb_ptr->static_ctx.sp = (cma__t_hppa_regs *) tcb_ptr->static_ctx.sp = (cma__t_hppa_regs *)
(extract_address (&deprecated_registers[REGISTER_BYTE (regno)], (extract_unsigned_integer (&deprecated_registers[REGISTER_BYTE (regno)],
REGISTER_RAW_SIZE (regno)) + 160); REGISTER_RAW_SIZE (regno)) + 160);
} }
else if (regno == PC_REGNUM) else if (regno == PC_REGNUM)
write_memory (sp - 20, write_memory (sp - 20,

View file

@ -1747,7 +1747,7 @@ generic_elf_find_global_pointer (CORE_ADDR faddr)
status = target_read_memory (addr + 8, buf, sizeof (buf)); status = target_read_memory (addr + 8, buf, sizeof (buf));
if (status != 0) if (status != 0)
break; break;
global_pointer = extract_address (buf, sizeof (buf)); global_pointer = extract_unsigned_integer (buf, sizeof (buf));
/* The payoff... */ /* The payoff... */
return global_pointer; return global_pointer;
@ -1929,7 +1929,7 @@ ia64_push_arguments (int nargs, struct value **args, CORE_ADDR sp,
char val_buf[8]; char val_buf[8];
store_unsigned_integer (val_buf, 8, store_unsigned_integer (val_buf, 8,
find_func_descr (extract_address (VALUE_CONTENTS (arg), 8), find_func_descr (extract_unsigned_integer (VALUE_CONTENTS (arg), 8),
&funcdescaddr)); &funcdescaddr));
if (slotnum < rseslots) if (slotnum < rseslots)
write_memory (rse_address_add (bsp, slotnum), val_buf, 8); write_memory (rse_address_add (bsp, slotnum), val_buf, 8);

View file

@ -156,7 +156,7 @@ get_longjmp_target (CORE_ADDR *pc)
TARGET_PTR_BIT / TARGET_CHAR_BIT)) TARGET_PTR_BIT / TARGET_CHAR_BIT))
return 0; return 0;
*pc = extract_address (buf, TARGET_PTR_BIT / TARGET_CHAR_BIT); *pc = extract_unsigned_integer (buf, TARGET_PTR_BIT / TARGET_CHAR_BIT);
return 1; return 1;
} }

View file

@ -174,7 +174,7 @@ get_longjmp_target (CORE_ADDR *pc)
TARGET_PTR_BIT / TARGET_CHAR_BIT)) TARGET_PTR_BIT / TARGET_CHAR_BIT))
return 0; return 0;
*pc = extract_address (buf, TARGET_PTR_BIT / TARGET_CHAR_BIT); *pc = extract_unsigned_integer (buf, TARGET_PTR_BIT / TARGET_CHAR_BIT);
return 1; return 1;
} }

View file

@ -1171,8 +1171,8 @@ m68hc11_return_value_on_stack (struct type *type)
static CORE_ADDR static CORE_ADDR
m68hc11_extract_struct_value_address (char *regbuf) m68hc11_extract_struct_value_address (char *regbuf)
{ {
return extract_address (&regbuf[HARD_D_REGNUM * 2], return extract_unsigned_integer (&regbuf[HARD_D_REGNUM * 2],
REGISTER_RAW_SIZE (HARD_D_REGNUM)); REGISTER_RAW_SIZE (HARD_D_REGNUM));
} }
/* Function: push_return_address (pc) /* Function: push_return_address (pc)

View file

@ -847,13 +847,13 @@ m68k_get_longjmp_target (CORE_ADDR *pc)
buf, TARGET_PTR_BIT / TARGET_CHAR_BIT)) buf, TARGET_PTR_BIT / TARGET_CHAR_BIT))
return 0; return 0;
jb_addr = extract_address (buf, TARGET_PTR_BIT / TARGET_CHAR_BIT); jb_addr = extract_unsigned_integer (buf, TARGET_PTR_BIT / TARGET_CHAR_BIT);
if (target_read_memory (jb_addr + tdep->jb_pc * tdep->jb_elt_size, buf, if (target_read_memory (jb_addr + tdep->jb_pc * tdep->jb_elt_size, buf,
TARGET_PTR_BIT / TARGET_CHAR_BIT)) TARGET_PTR_BIT / TARGET_CHAR_BIT))
return 0; return 0;
*pc = extract_address (buf, TARGET_PTR_BIT / TARGET_CHAR_BIT); *pc = extract_unsigned_integer (buf, TARGET_PTR_BIT / TARGET_CHAR_BIT);
return 1; return 1;
} }

View file

@ -992,7 +992,7 @@ mcore_use_struct_convention (int gcc_p, struct type *type)
CORE_ADDR CORE_ADDR
mcore_extract_struct_value_address (char *regbuf) mcore_extract_struct_value_address (char *regbuf)
{ {
return extract_address (regbuf + REGISTER_BYTE (FIRST_ARGREG), DEPRECATED_REGISTER_SIZE); return extract_unsigned_integer (regbuf + REGISTER_BYTE (FIRST_ARGREG), DEPRECATED_REGISTER_SIZE);
} }
/* Given a function which returns a value of type TYPE, extract the /* Given a function which returns a value of type TYPE, extract the

View file

@ -80,7 +80,7 @@ mips_linux_get_longjmp_target (CORE_ADDR *pc)
buf, TARGET_PTR_BIT / TARGET_CHAR_BIT)) buf, TARGET_PTR_BIT / TARGET_CHAR_BIT))
return 0; return 0;
*pc = extract_address (buf, TARGET_PTR_BIT / TARGET_CHAR_BIT); *pc = extract_unsigned_integer (buf, TARGET_PTR_BIT / TARGET_CHAR_BIT);
return 1; return 1;
} }
@ -367,7 +367,7 @@ mips64_linux_get_longjmp_target (CORE_ADDR *pc)
buf, TARGET_PTR_BIT / TARGET_CHAR_BIT)) buf, TARGET_PTR_BIT / TARGET_CHAR_BIT))
return 0; return 0;
*pc = extract_address (buf, TARGET_PTR_BIT / TARGET_CHAR_BIT); *pc = extract_unsigned_integer (buf, TARGET_PTR_BIT / TARGET_CHAR_BIT);
return 1; return 1;
} }

View file

@ -150,7 +150,7 @@ get_longjmp_target (CORE_ADDR *pc)
TARGET_PTR_BIT / TARGET_CHAR_BIT)) TARGET_PTR_BIT / TARGET_CHAR_BIT))
return 0; return 0;
*pc = extract_address (buf, TARGET_PTR_BIT / TARGET_CHAR_BIT); *pc = extract_unsigned_integer (buf, TARGET_PTR_BIT / TARGET_CHAR_BIT);
return 1; return 1;
} }

View file

@ -250,7 +250,7 @@ mipsnbsd_get_longjmp_target (CORE_ADDR *pc)
NBSD_MIPS_JB_ELEMENT_SIZE)) NBSD_MIPS_JB_ELEMENT_SIZE))
return 0; return 0;
*pc = extract_address (buf, NBSD_MIPS_JB_ELEMENT_SIZE); *pc = extract_unsigned_integer (buf, NBSD_MIPS_JB_ELEMENT_SIZE);
return 1; return 1;
} }

View file

@ -154,7 +154,7 @@ get_longjmp_target (CORE_ADDR *pc)
TARGET_PTR_BIT / TARGET_CHAR_BIT)) TARGET_PTR_BIT / TARGET_CHAR_BIT))
return 0; return 0;
*pc = extract_address (buf, TARGET_PTR_BIT / TARGET_CHAR_BIT); *pc = extract_unsigned_integer (buf, TARGET_PTR_BIT / TARGET_CHAR_BIT);
return 1; return 1;
} }

View file

@ -131,8 +131,8 @@ mn10300_extract_return_value (struct type *type, char *regbuf, char *valbuf)
static CORE_ADDR static CORE_ADDR
mn10300_extract_struct_value_address (char *regbuf) mn10300_extract_struct_value_address (char *regbuf)
{ {
return extract_address (regbuf + REGISTER_BYTE (4), return extract_unsigned_integer (regbuf + REGISTER_BYTE (4),
REGISTER_RAW_SIZE (4)); REGISTER_RAW_SIZE (4));
} }
static void static void

View file

@ -503,7 +503,7 @@ ns32k_store_return_value (struct type *valtype, char *valbuf)
static CORE_ADDR static CORE_ADDR
ns32k_extract_struct_value_address (char *regbuf) ns32k_extract_struct_value_address (char *regbuf)
{ {
return (extract_address (regbuf + REGISTER_BYTE (0), REGISTER_RAW_SIZE (0))); return (extract_unsigned_integer (regbuf + REGISTER_BYTE (0), REGISTER_RAW_SIZE (0)));
} }
void void

View file

@ -295,7 +295,7 @@ ppc_linux_skip_trampoline_code (CORE_ADDR pc)
/* Get address of the relocation entry (Elf32_Rela) */ /* Get address of the relocation entry (Elf32_Rela) */
if (target_read_memory (plt_table + reloc_index, buf, 4) != 0) if (target_read_memory (plt_table + reloc_index, buf, 4) != 0)
return 0; return 0;
reloc = extract_address (buf, 4); reloc = extract_unsigned_integer (buf, 4);
sect = find_pc_section (reloc); sect = find_pc_section (reloc);
if (!sect) if (!sect)

View file

@ -101,8 +101,8 @@ vx_read_register (int regno)
area in the frame. VxWorks does not do this for the active frame area in the frame. VxWorks does not do this for the active frame
automatically; it greatly simplifies debugging. */ automatically; it greatly simplifies debugging. */
sp = extract_address (&deprecated_registers[REGISTER_BYTE (SP_REGNUM)], sp = extract_unsigned_integer (&deprecated_registers[REGISTER_BYTE (SP_REGNUM)],
REGISTER_RAW_SIZE (SP_REGNUM)); REGISTER_RAW_SIZE (SP_REGNUM));
write_memory (sp, &deprecated_registers[REGISTER_BYTE (L0_REGNUM)], write_memory (sp, &deprecated_registers[REGISTER_BYTE (L0_REGNUM)],
16 * REGISTER_RAW_SIZE (L0_REGNUM)); 16 * REGISTER_RAW_SIZE (L0_REGNUM));
@ -176,8 +176,8 @@ vx_write_register (int regno)
if (regno < 0 || (L0_REGNUM <= regno && regno <= I7_REGNUM)) if (regno < 0 || (L0_REGNUM <= regno && regno <= I7_REGNUM))
{ {
sp = extract_address (&deprecated_registers[REGISTER_BYTE (SP_REGNUM)], sp = extract_unsigned_integer (&deprecated_registers[REGISTER_BYTE (SP_REGNUM)],
REGISTER_RAW_SIZE (SP_REGNUM)); REGISTER_RAW_SIZE (SP_REGNUM));
write_memory (sp, &deprecated_registers[REGISTER_BYTE (L0_REGNUM)], write_memory (sp, &deprecated_registers[REGISTER_BYTE (L0_REGNUM)],
16 * REGISTER_RAW_SIZE (L0_REGNUM)); 16 * REGISTER_RAW_SIZE (L0_REGNUM));
} }

View file

@ -1921,14 +1921,14 @@ sh64_get_saved_register (char *raw_buffer, int *optimized, CORE_ADDR *addrp,
static CORE_ADDR static CORE_ADDR
sh_extract_struct_value_address (char *regbuf) sh_extract_struct_value_address (char *regbuf)
{ {
return (extract_address ((regbuf), REGISTER_RAW_SIZE (0))); return (extract_unsigned_integer ((regbuf), REGISTER_RAW_SIZE (0)));
} }
static CORE_ADDR static CORE_ADDR
sh64_extract_struct_value_address (char *regbuf) sh64_extract_struct_value_address (char *regbuf)
{ {
return (extract_address ((regbuf + REGISTER_BYTE (STRUCT_RETURN_REGNUM)), return (extract_unsigned_integer ((regbuf + REGISTER_BYTE (STRUCT_RETURN_REGNUM)),
REGISTER_RAW_SIZE (STRUCT_RETURN_REGNUM))); REGISTER_RAW_SIZE (STRUCT_RETURN_REGNUM)));
} }
static CORE_ADDR static CORE_ADDR
@ -2123,7 +2123,7 @@ sh_push_arguments (int nargs, struct value **args, CORE_ADDR sp,
if (argreg <= tdep->ARGLAST_REGNUM) if (argreg <= tdep->ARGLAST_REGNUM)
{ {
/* there's room in a register */ /* there's room in a register */
regval = extract_address (val, REGISTER_RAW_SIZE (argreg)); regval = extract_unsigned_integer (val, REGISTER_RAW_SIZE (argreg));
write_register (argreg++, regval); write_register (argreg++, regval);
} }
/* Store the value 4 bytes at a time. This means that things /* Store the value 4 bytes at a time. This means that things
@ -2238,7 +2238,7 @@ sh64_push_arguments (int nargs, struct value **args, CORE_ADDR sp,
if (int_argreg <= tdep->ARGLAST_REGNUM) if (int_argreg <= tdep->ARGLAST_REGNUM)
{ {
/* there's room in a register */ /* there's room in a register */
regval = extract_address (val, argreg_size); regval = extract_unsigned_integer (val, argreg_size);
write_register (int_argreg, regval); write_register (int_argreg, regval);
} }
/* Store the value 8 bytes at a time. This means that /* Store the value 8 bytes at a time. This means that

View file

@ -508,7 +508,7 @@ sparc_frame_saved_pc (struct frame_info *frame)
stack layout has changed or the stack is corrupt. */ stack layout has changed or the stack is corrupt. */
target_read_memory (sigcontext_addr + saved_pc_offset, target_read_memory (sigcontext_addr + saved_pc_offset,
scbuf, sizeof (scbuf)); scbuf, sizeof (scbuf));
return extract_address (scbuf, sizeof (scbuf)); return extract_unsigned_integer (scbuf, sizeof (scbuf));
} }
else if (get_frame_extra_info (frame)->in_prologue || else if (get_frame_extra_info (frame)->in_prologue ||
(get_next_frame (frame) != NULL && (get_next_frame (frame) != NULL &&
@ -534,7 +534,7 @@ sparc_frame_saved_pc (struct frame_info *frame)
return PC_ADJUST (read_register (O7_REGNUM)); return PC_ADJUST (read_register (O7_REGNUM));
read_memory (addr, buf, SPARC_INTREG_SIZE); read_memory (addr, buf, SPARC_INTREG_SIZE);
return PC_ADJUST (extract_address (buf, SPARC_INTREG_SIZE)); return PC_ADJUST (extract_unsigned_integer (buf, SPARC_INTREG_SIZE));
} }
/* Since an individual frame in the frame cache is defined by two /* Since an individual frame in the frame cache is defined by two
@ -1796,7 +1796,7 @@ get_longjmp_target (CORE_ADDR *pc)
LONGJMP_TARGET_SIZE)) LONGJMP_TARGET_SIZE))
return 0; return 0;
*pc = extract_address (buf, LONGJMP_TARGET_SIZE); *pc = extract_unsigned_integer (buf, LONGJMP_TARGET_SIZE);
return 1; return 1;
} }

View file

@ -447,7 +447,7 @@ sparcnbsd_get_longjmp_target_32 (CORE_ADDR *pc)
if (target_read_memory (jb_addr + 12, buf, sizeof (buf))) if (target_read_memory (jb_addr + 12, buf, sizeof (buf)))
return 0; return 0;
*pc = extract_address (buf, sizeof (buf)); *pc = extract_unsigned_integer (buf, sizeof (buf));
return 1; return 1;
} }
@ -463,7 +463,7 @@ sparcnbsd_get_longjmp_target_64 (CORE_ADDR *pc)
if (target_read_memory (jb_addr + 16, buf, sizeof (buf))) if (target_read_memory (jb_addr + 16, buf, sizeof (buf)))
return 0; return 0;
*pc = extract_address (buf, sizeof (buf)); *pc = extract_unsigned_integer (buf, sizeof (buf));
return 1; return 1;
} }

View file

@ -973,7 +973,7 @@ v850_push_arguments (int nargs, struct value **args, CORE_ADDR sp,
{ {
CORE_ADDR regval; CORE_ADDR regval;
regval = extract_address (val, v850_register_raw_size (argreg)); regval = extract_unsigned_integer (val, v850_register_raw_size (argreg));
write_register (argreg, regval); write_register (argreg, regval);
len -= v850_register_raw_size (argreg); len -= v850_register_raw_size (argreg);
@ -1068,8 +1068,8 @@ v850_extract_return_value (struct type *type, char *regbuf, char *valbuf)
/* Aggregates and return values > 8 bytes are returned in memory, /* Aggregates and return values > 8 bytes are returned in memory,
pointed to by R6. */ pointed to by R6. */
return_buffer = return_buffer =
extract_address (regbuf + REGISTER_BYTE (E_V0_REGNUM), extract_unsigned_integer (regbuf + REGISTER_BYTE (E_V0_REGNUM),
REGISTER_RAW_SIZE (E_V0_REGNUM)); REGISTER_RAW_SIZE (E_V0_REGNUM));
read_memory (return_buffer, valbuf, TYPE_LENGTH (type)); read_memory (return_buffer, valbuf, TYPE_LENGTH (type));
} }
@ -1086,8 +1086,8 @@ v850_breakpoint_from_pc (CORE_ADDR *pcptr, int *lenptr)
static CORE_ADDR static CORE_ADDR
v850_extract_struct_value_address (char *regbuf) v850_extract_struct_value_address (char *regbuf)
{ {
return extract_address (regbuf + v850_register_byte (E_V0_REGNUM), return extract_unsigned_integer (regbuf + v850_register_byte (E_V0_REGNUM),
v850_register_raw_size (E_V0_REGNUM)); v850_register_raw_size (E_V0_REGNUM));
} }
static void static void

View file

@ -300,7 +300,8 @@ vax_store_return_value (struct type *valtype, char *valbuf)
static CORE_ADDR static CORE_ADDR
vax_extract_struct_value_address (char *regbuf) vax_extract_struct_value_address (char *regbuf)
{ {
return (extract_address (regbuf + REGISTER_BYTE (0), REGISTER_RAW_SIZE (0))); return (extract_unsigned_integer (regbuf + REGISTER_BYTE (0),
REGISTER_RAW_SIZE (0)));
} }
static const unsigned char * static const unsigned char *

View file

@ -228,8 +228,8 @@ xstormy16_extract_return_value (struct type *type, char *regbuf, char *valbuf)
/* Aggregates and return values > 12 bytes are returned in memory, /* Aggregates and return values > 12 bytes are returned in memory,
pointed to by R2. */ pointed to by R2. */
return_buffer = return_buffer =
extract_address (regbuf + REGISTER_BYTE (E_PTR_RET_REGNUM), extract_unsigned_integer (regbuf + REGISTER_BYTE (E_PTR_RET_REGNUM),
REGISTER_RAW_SIZE (E_PTR_RET_REGNUM)); REGISTER_RAW_SIZE (E_PTR_RET_REGNUM));
read_memory (return_buffer, valbuf, TYPE_LENGTH (type)); read_memory (return_buffer, valbuf, TYPE_LENGTH (type));
} }
@ -410,9 +410,8 @@ xstormy16_store_return_value (struct type *type, char *valbuf)
static CORE_ADDR static CORE_ADDR
xstormy16_extract_struct_value_address (char *regbuf) xstormy16_extract_struct_value_address (char *regbuf)
{ {
return extract_address (regbuf + return extract_unsigned_integer (regbuf + xstormy16_register_byte (E_PTR_RET_REGNUM),
xstormy16_register_byte (E_PTR_RET_REGNUM), xstormy16_reg_size);
xstormy16_reg_size);
} }
/* Function: xstormy16_use_struct_convention /* Function: xstormy16_use_struct_convention
@ -962,7 +961,7 @@ static CORE_ADDR
xstormy16_pointer_to_address (struct type *type, const void *buf) xstormy16_pointer_to_address (struct type *type, const void *buf)
{ {
enum type_code target = TYPE_CODE (TYPE_TARGET_TYPE (type)); enum type_code target = TYPE_CODE (TYPE_TARGET_TYPE (type));
CORE_ADDR addr = extract_address (buf, TYPE_LENGTH (type)); CORE_ADDR addr = extract_unsigned_integer (buf, TYPE_LENGTH (type));
if (target == TYPE_CODE_FUNC || target == TYPE_CODE_METHOD) if (target == TYPE_CODE_FUNC || target == TYPE_CODE_METHOD)
{ {