Commit dd542a2b authored by palfia@homejinni.com's avatar palfia@homejinni.com

MIPS: Fix unaligned address of double.

TEST=mjsunit/debug-evaluate-locals-optimized-double

BUG=

Review URL: https://codereview.chromium.org/14631016

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@14828 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent a5f949be
...@@ -38,6 +38,24 @@ ...@@ -38,6 +38,24 @@
namespace v8 { namespace v8 {
namespace internal { namespace internal {
static inline double read_double_value(Address p) {
#ifdef V8_HOST_CAN_READ_UNALIGNED
return Memory::double_at(p);
#else // V8_HOST_CAN_READ_UNALIGNED
// Prevent gcc from using load-double (mips ldc1) on (possibly)
// non-64-bit aligned address.
union conversion {
double d;
uint32_t u[2];
} c;
c.u[0] = *reinterpret_cast<uint32_t*>(p);
c.u[1] = *reinterpret_cast<uint32_t*>(p + 4);
return c.d;
#endif // V8_HOST_CAN_READ_UNALIGNED
}
class FrameDescription; class FrameDescription;
class TranslationIterator; class TranslationIterator;
class DeoptimizingCodeListNode; class DeoptimizingCodeListNode;
...@@ -476,19 +494,7 @@ class FrameDescription { ...@@ -476,19 +494,7 @@ class FrameDescription {
double GetDoubleFrameSlot(unsigned offset) { double GetDoubleFrameSlot(unsigned offset) {
intptr_t* ptr = GetFrameSlotPointer(offset); intptr_t* ptr = GetFrameSlotPointer(offset);
#if V8_TARGET_ARCH_MIPS return read_double_value(reinterpret_cast<Address>(ptr));
// Prevent gcc from using load-double (mips ldc1) on (possibly)
// non-64-bit aligned double. Uses two lwc1 instructions.
union conversion {
double d;
uint32_t u[2];
} c;
c.u[0] = *reinterpret_cast<uint32_t*>(ptr);
c.u[1] = *(reinterpret_cast<uint32_t*>(ptr) + 1);
return c.d;
#else
return *reinterpret_cast<double*>(ptr);
#endif
} }
void SetFrameSlot(unsigned offset, intptr_t value) { void SetFrameSlot(unsigned offset, intptr_t value) {
...@@ -818,7 +824,7 @@ class SlotRef BASE_EMBEDDED { ...@@ -818,7 +824,7 @@ class SlotRef BASE_EMBEDDED {
} }
case DOUBLE: { case DOUBLE: {
double value = Memory::double_at(addr_); double value = read_double_value(addr_);
return isolate->factory()->NewNumber(value); return isolate->factory()->NewNumber(value);
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment