2002-06-06 Elena Zannoni <ezannoni@redhat.com>

* d10v-tdep.c (d10v_read_sp, d10v_read_fp): Add prototype.
        (d10v_register_virtual_type): Make $fp and $sp be pointer to data.
        (d10v_integer_to_address): Rewrite.
        (d10v_frame_init_saved_regs): When reading fp and sp registers use
        the d10v specific functions which take care of converting to the
        correct space.
This commit is contained in:
Elena Zannoni 2002-06-06 16:35:37 +00:00
parent c93abbccf2
commit 095a4c965d
2 changed files with 22 additions and 11 deletions

View file

@ -1,3 +1,12 @@
2002-06-06 Elena Zannoni <ezannoni@redhat.com>
* d10v-tdep.c (d10v_read_sp, d10v_read_fp): Add prototype.
(d10v_register_virtual_type): Make $fp and $sp be pointer to data.
(d10v_integer_to_address): Rewrite.
(d10v_frame_init_saved_regs): When reading fp and sp registers use
the d10v specific functions which take care of converting to the
correct space.
2002-06-06 Elena Zannoni <ezannoni@redhat.com>
* config/djgpp/fnchange.lst: Add testsuite files altivec-abi.c,

View file

@ -95,6 +95,10 @@ enum
extern void _initialize_d10v_tdep (void);
static CORE_ADDR d10v_read_sp (void);
static CORE_ADDR d10v_read_fp (void);
static void d10v_eva_prepare_to_trace (void);
static void d10v_eva_get_trace_data (void);
@ -366,6 +370,8 @@ d10v_register_virtual_type (int reg_nr)
{
if (reg_nr == PC_REGNUM)
return builtin_type_void_func_ptr;
if (reg_nr == _SP_REGNUM || reg_nr == _FP_REGNUM)
return builtin_type_void_data_ptr;
else if (reg_nr >= A0_REGNUM
&& reg_nr < (A0_REGNUM + NR_A_REGS))
return builtin_type_int64;
@ -444,19 +450,15 @@ d10v_pointer_to_address (struct type *type, void *buf)
return d10v_make_daddr (addr);
}
/* Don't do anything if we have an integer, this way users can type 'x
<addr>' w/o having gdb outsmart them. The internal gdb conversions
to the correct space are taken care of in the pointer_to_address
function. If we don't do this, 'x $fp' wouldn't work. */
static CORE_ADDR
d10v_integer_to_address (struct type *type, void *buf)
{
LONGEST val;
val = unpack_long (type, buf);
if (TYPE_CODE (type) == TYPE_CODE_INT
&& TYPE_LENGTH (type) <= TYPE_LENGTH (builtin_type_void_data_ptr))
/* Convert small integers that would would be directly copied into
a pointer variable into an address pointing into data space. */
return d10v_make_daddr (val & 0xffff);
else
/* The value is too large to fit in a pointer. Assume this was
intentional and that the user in fact specified a raw address. */
return val;
}
@ -848,7 +850,7 @@ d10v_frame_init_saved_regs (struct frame_info *fi)
fi->extra_info->size = -next_addr;
if (!(fp & 0xffff))
fp = d10v_make_daddr (read_register (SP_REGNUM));
fp = d10v_read_sp ();
for (i = 0; i < NUM_REGS - 1; i++)
if (fi->saved_regs[i])
@ -875,7 +877,7 @@ d10v_frame_init_saved_regs (struct frame_info *fi)
/* otherwise, it isn't being used, so we use the SP instead */
if (uses_frame)
fi->saved_regs[SP_REGNUM]
= read_register (FP_REGNUM) + fi->extra_info->size;
= d10v_read_fp () + fi->extra_info->size;
else
{
fi->saved_regs[SP_REGNUM] = fp + fi->extra_info->size;