From d85fe7f7fa4862015a50e89ec9b845e8155c2b0a Mon Sep 17 00:00:00 2001 From: Andreas Schwab Date: Fri, 22 Nov 2002 00:02:03 +0000 Subject: * m68k-tdep.c (m68k_register_virtual_type): Return int for SR, FPC and FPS registers. --- gdb/ChangeLog | 5 +++++ gdb/m68k-tdep.c | 19 ++++++++++++------- 2 files changed, 17 insertions(+), 7 deletions(-) (limited to 'gdb') diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 0946917..b408b51 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,8 @@ +2002-11-22 Andreas Schwab + + * m68k-tdep.c (m68k_register_virtual_type): Return int for SR, FPC + and FPS registers. + 2002-11-21 Daniel Jacobowitz * maint.c (_initialize_maint_cmds): Fix typo. From diff --git a/gdb/m68k-tdep.c b/gdb/m68k-tdep.c index 250f681..7039e64 100644 --- a/gdb/m68k-tdep.c +++ b/gdb/m68k-tdep.c @@ -148,20 +148,25 @@ m68k_register_virtual_size (int regnum) return (((unsigned) (regnum) - FP0_REGNUM) < 8 ? 12 : 4); } -/* Return the GDB type object for the "standard" data type of data - in register N. This should be int for D0-D7, long double for FP0-FP7, - and void pointer for all others (A0-A7, PC, SR, FPCONTROL etc). - Note, for registers which contain addresses return pointer to void, - not pointer to char, because we don't want to attempt to print - the string after printing the address. */ +/* Return the GDB type object for the "standard" data type of data in + register N. This should be int for D0-D7, SR, FPCONTROL and + FPSTATUS, long double for FP0-FP7, and void pointer for all others + (A0-A7, PC, FPIADDR). Note, for registers which contain + addresses return pointer to void, not pointer to char, because we + don't want to attempt to print the string after printing the + address. */ static struct type * m68k_register_virtual_type (int regnum) { - if ((unsigned) regnum >= E_FPC_REGNUM) + if (regnum == E_FPI_REGNUM) return lookup_pointer_type (builtin_type_void); + else if ((unsigned) regnum >= E_FPC_REGNUM) + return builtin_type_int; else if ((unsigned) regnum >= FP0_REGNUM) return builtin_type_long_double; + else if (regnum == PS_REGNUM) + return builtin_type_int; else if ((unsigned) regnum >= A0_REGNUM) return lookup_pointer_type (builtin_type_void); else -- cgit v1.1