| 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 "lib/error.h" | 10 #include "lib/error.h" |
| (...skipping 1318 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1329 __ Drop(1); | 1329 __ Drop(1); |
| 1330 __ jmp(skip_call); | 1330 __ jmp(skip_call); |
| 1331 __ Bind(&fall_through); | 1331 __ Bind(&fall_through); |
| 1332 } | 1332 } |
| 1333 | 1333 |
| 1334 | 1334 |
| 1335 void FlowGraphCompiler::SaveLiveRegisters(LocationSummary* locs) { | 1335 void FlowGraphCompiler::SaveLiveRegisters(LocationSummary* locs) { |
| 1336 // TODO(vegorov): consider saving only caller save (volatile) registers. | 1336 // TODO(vegorov): consider saving only caller save (volatile) registers. |
| 1337 const intptr_t xmm_regs_count = locs->live_registers()->fpu_regs_count(); | 1337 const intptr_t xmm_regs_count = locs->live_registers()->fpu_regs_count(); |
| 1338 if (xmm_regs_count > 0) { | 1338 if (xmm_regs_count > 0) { |
| 1339 __ subq(RSP, Immediate(xmm_regs_count * kDoubleSize)); | 1339 __ subq(RSP, Immediate(xmm_regs_count * kFpuRegisterSize)); |
| 1340 // Store XMM registers with the lowest register number at the lowest | 1340 // Store XMM registers with the lowest register number at the lowest |
| 1341 // address. | 1341 // address. |
| 1342 intptr_t offset = 0; | 1342 intptr_t offset = 0; |
| 1343 for (intptr_t reg_idx = 0; reg_idx < kNumberOfXmmRegisters; ++reg_idx) { | 1343 for (intptr_t reg_idx = 0; reg_idx < kNumberOfXmmRegisters; ++reg_idx) { |
| 1344 XmmRegister xmm_reg = static_cast<XmmRegister>(reg_idx); | 1344 XmmRegister xmm_reg = static_cast<XmmRegister>(reg_idx); |
| 1345 if (locs->live_registers()->ContainsFpuRegister(xmm_reg)) { | 1345 if (locs->live_registers()->ContainsFpuRegister(xmm_reg)) { |
| 1346 __ movsd(Address(RSP, offset), xmm_reg); | 1346 __ movups(Address(RSP, offset), xmm_reg); |
| 1347 offset += kDoubleSize; | 1347 offset += kFpuRegisterSize; |
| 1348 } | 1348 } |
| 1349 } | 1349 } |
| 1350 ASSERT(offset == (xmm_regs_count * kDoubleSize)); | 1350 ASSERT(offset == (xmm_regs_count * kFpuRegisterSize)); |
| 1351 } | 1351 } |
| 1352 | 1352 |
| 1353 // Store general purpose registers with the highest register number at the | 1353 // Store general purpose registers with the highest register number at the |
| 1354 // lowest address. | 1354 // lowest address. |
| 1355 for (intptr_t reg_idx = 0; reg_idx < kNumberOfCpuRegisters; ++reg_idx) { | 1355 for (intptr_t reg_idx = 0; reg_idx < kNumberOfCpuRegisters; ++reg_idx) { |
| 1356 Register reg = static_cast<Register>(reg_idx); | 1356 Register reg = static_cast<Register>(reg_idx); |
| 1357 if (locs->live_registers()->ContainsRegister(reg)) { | 1357 if (locs->live_registers()->ContainsRegister(reg)) { |
| 1358 __ pushq(reg); | 1358 __ pushq(reg); |
| 1359 } | 1359 } |
| 1360 } | 1360 } |
| (...skipping 10 matching lines...) Expand all Loading... |
| 1371 } | 1371 } |
| 1372 } | 1372 } |
| 1373 | 1373 |
| 1374 const intptr_t xmm_regs_count = locs->live_registers()->fpu_regs_count(); | 1374 const intptr_t xmm_regs_count = locs->live_registers()->fpu_regs_count(); |
| 1375 if (xmm_regs_count > 0) { | 1375 if (xmm_regs_count > 0) { |
| 1376 // XMM registers have the lowest register number at the lowest address. | 1376 // XMM registers have the lowest register number at the lowest address. |
| 1377 intptr_t offset = 0; | 1377 intptr_t offset = 0; |
| 1378 for (intptr_t reg_idx = 0; reg_idx < kNumberOfXmmRegisters; ++reg_idx) { | 1378 for (intptr_t reg_idx = 0; reg_idx < kNumberOfXmmRegisters; ++reg_idx) { |
| 1379 XmmRegister xmm_reg = static_cast<XmmRegister>(reg_idx); | 1379 XmmRegister xmm_reg = static_cast<XmmRegister>(reg_idx); |
| 1380 if (locs->live_registers()->ContainsFpuRegister(xmm_reg)) { | 1380 if (locs->live_registers()->ContainsFpuRegister(xmm_reg)) { |
| 1381 __ movsd(xmm_reg, Address(RSP, offset)); | 1381 __ movups(xmm_reg, Address(RSP, offset)); |
| 1382 offset += kDoubleSize; | 1382 offset += kFpuRegisterSize; |
| 1383 } | 1383 } |
| 1384 } | 1384 } |
| 1385 ASSERT(offset == (xmm_regs_count * kDoubleSize)); | 1385 ASSERT(offset == (xmm_regs_count * kFpuRegisterSize)); |
| 1386 __ addq(RSP, Immediate(offset)); | 1386 __ addq(RSP, Immediate(offset)); |
| 1387 } | 1387 } |
| 1388 } | 1388 } |
| 1389 | 1389 |
| 1390 | 1390 |
| 1391 void FlowGraphCompiler::EmitTestAndCall(const ICData& ic_data, | 1391 void FlowGraphCompiler::EmitTestAndCall(const ICData& ic_data, |
| 1392 Register class_id_reg, | 1392 Register class_id_reg, |
| 1393 intptr_t arg_count, | 1393 intptr_t arg_count, |
| 1394 const Array& arg_names, | 1394 const Array& arg_names, |
| 1395 Label* deopt, | 1395 Label* deopt, |
| (...skipping 286 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1682 void ParallelMoveResolver::Exchange(const Address& mem1, const Address& mem2) { | 1682 void ParallelMoveResolver::Exchange(const Address& mem1, const Address& mem2) { |
| 1683 __ Exchange(mem1, mem2); | 1683 __ Exchange(mem1, mem2); |
| 1684 } | 1684 } |
| 1685 | 1685 |
| 1686 | 1686 |
| 1687 #undef __ | 1687 #undef __ |
| 1688 | 1688 |
| 1689 } // namespace dart | 1689 } // namespace dart |
| 1690 | 1690 |
| 1691 #endif // defined TARGET_ARCH_X64 | 1691 #endif // defined TARGET_ARCH_X64 |
| OLD | NEW |