summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--arch/mips/isa_traits.hh6
-rwxr-xr-xconfigs/test/hello_mipsbin837718 -> 837626 bytes
2 files changed, 4 insertions, 2 deletions
diff --git a/arch/mips/isa_traits.hh b/arch/mips/isa_traits.hh
index 3879eaf40..74947c6dd 100644
--- a/arch/mips/isa_traits.hh
+++ b/arch/mips/isa_traits.hh
@@ -190,6 +190,7 @@ namespace MipsISA
};
typedef float FloatReg;
+ typedef double FPVal;
typedef uint32_t FloatReg32;
typedef uint64_t FloatReg64;
@@ -230,7 +231,8 @@ namespace MipsISA
return *(float *) float_ptr;
case DoubleWidth:
- void *double_ptr = &regs[floatReg];
+ uint64_t double_val = (FloatReg64)regs[floatReg + 1] << 32 | regs[floatReg];
+ void *double_ptr = &double_val;
return *(double *) double_ptr;
default:
@@ -255,7 +257,7 @@ namespace MipsISA
}
}
- Fault setReg(int floatReg, const FloatReg &val, int width)
+ Fault setReg(int floatReg, const FPVal &val, int width)
{
switch(width)
diff --git a/configs/test/hello_mips b/configs/test/hello_mips
index 33d9fbb58..a3db001ec 100755
--- a/configs/test/hello_mips
+++ b/configs/test/hello_mips
Binary files differ