From: Kevin Buettner Date: Thu, 1 Aug 2002 23:10:34 +0000 (+0000) Subject: * mips-tdep.c (mips_register_virtual_type): Use architecture X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=a642592427cf8c41f51cbd9ad352875a1094bbe9;p=binutils-gdb.git * mips-tdep.c (mips_register_virtual_type): Use architecture invariant return values. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 97b01e313e3..347b4bf2eeb 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,8 @@ +2002-08-01 Kevin Buettner + + * mips-tdep.c (mips_register_virtual_type): Use architecture + invariant return values. + 2002-08-01 Andrew Cagney * linux-proc.c: Include "gdb_string.h". diff --git a/gdb/mips-tdep.c b/gdb/mips-tdep.c index de7946e8e85..45b5813e747 100644 --- a/gdb/mips-tdep.c +++ b/gdb/mips-tdep.c @@ -497,19 +497,25 @@ static struct type * mips_register_virtual_type (int reg) { if (FP0_REGNUM <= reg && reg < FP0_REGNUM + 32) - return builtin_type_double; + { + /* Floating point registers... */ + if (TARGET_BYTE_ORDER == BFD_ENDIAN_BIG) + return builtin_type_ieee_double_big; + else + return builtin_type_ieee_double_little; + } else if (reg == PS_REGNUM /* CR */) return builtin_type_uint32; else if (FCRCS_REGNUM <= reg && reg <= LAST_EMBED_REGNUM) return builtin_type_uint32; else { - /* Everything else... return ``long long'' when registers - are 64-bits wide, ``int'' otherwise. */ - if (MIPS_REGSIZE == TYPE_LENGTH (builtin_type_long_long)) - return builtin_type_long_long; + /* Everything else... + Return type appropriate for width of register. */ + if (MIPS_REGSIZE == TYPE_LENGTH (builtin_type_uint64)) + return builtin_type_uint64; else - return builtin_type_int; + return builtin_type_uint32; } }