| OLD | NEW |
| 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file |
| 2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
| 3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
| 4 | 4 |
| 5 #include "vm/globals.h" // Needed here to get TARGET_ARCH_X64. | 5 #include "vm/globals.h" // Needed here to get TARGET_ARCH_X64. |
| 6 #if defined(TARGET_ARCH_X64) | 6 #if defined(TARGET_ARCH_X64) |
| 7 | 7 |
| 8 #include "vm/flow_graph_compiler.h" | 8 #include "vm/flow_graph_compiler.h" |
| 9 | 9 |
| 10 #include "vm/ast_printer.h" | 10 #include "vm/ast_printer.h" |
| (...skipping 1561 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1572 } else { | 1572 } else { |
| 1573 ASSERT(source.IsConstant()); | 1573 ASSERT(source.IsConstant()); |
| 1574 const Object& constant = source.constant(); | 1574 const Object& constant = source.constant(); |
| 1575 if (destination.IsRegister()) { | 1575 if (destination.IsRegister()) { |
| 1576 if (constant.IsSmi() && (Smi::Cast(constant).Value() == 0)) { | 1576 if (constant.IsSmi() && (Smi::Cast(constant).Value() == 0)) { |
| 1577 __ xorq(destination.reg(), destination.reg()); | 1577 __ xorq(destination.reg(), destination.reg()); |
| 1578 } else { | 1578 } else { |
| 1579 __ LoadObject(destination.reg(), constant, PP); | 1579 __ LoadObject(destination.reg(), constant, PP); |
| 1580 } | 1580 } |
| 1581 } else if (destination.IsFpuRegister()) { | 1581 } else if (destination.IsFpuRegister()) { |
| 1582 __ LoadObject(TMP, constant, PP); | 1582 if (Utils::DoublesBitEqual(Double::Cast(constant).value(), 0.0)) { |
| 1583 __ movsd(destination.fpu_reg(), | 1583 __ xorps(destination.fpu_reg(), destination.fpu_reg()); |
| 1584 FieldAddress(TMP, Double::value_offset())); | 1584 } else { |
| 1585 __ LoadObject(TMP, constant, PP); |
| 1586 __ movsd(destination.fpu_reg(), |
| 1587 FieldAddress(TMP, Double::value_offset())); |
| 1588 } |
| 1585 } else if (destination.IsDoubleStackSlot()) { | 1589 } else if (destination.IsDoubleStackSlot()) { |
| 1586 __ LoadObject(TMP, constant, PP); | 1590 if (Utils::DoublesBitEqual(Double::Cast(constant).value(), 0.0)) { |
| 1587 __ movsd(XMM0, FieldAddress(TMP, Double::value_offset())); | 1591 __ xorps(XMM0, XMM0); |
| 1592 } else { |
| 1593 __ LoadObject(TMP, constant, PP); |
| 1594 __ movsd(XMM0, FieldAddress(TMP, Double::value_offset())); |
| 1595 } |
| 1588 __ movsd(destination.ToStackSlotAddress(), XMM0); | 1596 __ movsd(destination.ToStackSlotAddress(), XMM0); |
| 1589 } else { | 1597 } else { |
| 1590 ASSERT(destination.IsStackSlot()); | 1598 ASSERT(destination.IsStackSlot()); |
| 1591 StoreObject(destination.ToStackSlotAddress(), constant); | 1599 StoreObject(destination.ToStackSlotAddress(), constant); |
| 1592 } | 1600 } |
| 1593 } | 1601 } |
| 1594 | 1602 |
| 1595 move->Eliminate(); | 1603 move->Eliminate(); |
| 1596 } | 1604 } |
| 1597 | 1605 |
| (...skipping 128 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1726 __ movups(reg, Address(RSP, 0)); | 1734 __ movups(reg, Address(RSP, 0)); |
| 1727 __ AddImmediate(RSP, Immediate(kFpuRegisterSize), PP); | 1735 __ AddImmediate(RSP, Immediate(kFpuRegisterSize), PP); |
| 1728 } | 1736 } |
| 1729 | 1737 |
| 1730 | 1738 |
| 1731 #undef __ | 1739 #undef __ |
| 1732 | 1740 |
| 1733 } // namespace dart | 1741 } // namespace dart |
| 1734 | 1742 |
| 1735 #endif // defined TARGET_ARCH_X64 | 1743 #endif // defined TARGET_ARCH_X64 |
| OLD | NEW |