| OLD | NEW |
| 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2012, 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 12 matching lines...) Expand all Loading... |
| 23 DECLARE_FLAG(bool, print_scopes); | 23 DECLARE_FLAG(bool, print_scopes); |
| 24 DECLARE_FLAG(bool, trace_functions); | 24 DECLARE_FLAG(bool, trace_functions); |
| 25 | 25 |
| 26 | 26 |
| 27 void CompilerDeoptInfoWithStub::GenerateCode(FlowGraphCompiler* compiler, | 27 void CompilerDeoptInfoWithStub::GenerateCode(FlowGraphCompiler* compiler, |
| 28 intptr_t stub_ix) { | 28 intptr_t stub_ix) { |
| 29 // Calls do not need stubs, they share a deoptimization trampoline. | 29 // Calls do not need stubs, they share a deoptimization trampoline. |
| 30 ASSERT(reason() != kDeoptAtCall); | 30 ASSERT(reason() != kDeoptAtCall); |
| 31 Assembler* assem = compiler->assembler(); | 31 Assembler* assem = compiler->assembler(); |
| 32 #define __ assem-> | 32 #define __ assem-> |
| 33 __ Comment("Deopt stub for id %d", deopt_id()); | 33 __ Comment("Deopt stub for id %"Pd"", deopt_id()); |
| 34 __ Bind(entry_label()); | 34 __ Bind(entry_label()); |
| 35 | 35 |
| 36 ASSERT(deoptimization_env() != NULL); | 36 ASSERT(deoptimization_env() != NULL); |
| 37 | 37 |
| 38 if (compiler->IsLeaf()) { | 38 if (compiler->IsLeaf()) { |
| 39 __ Comment("Leaf method, lazy PC marker setup"); | 39 __ Comment("Leaf method, lazy PC marker setup"); |
| 40 // TODO(srdjan): Can we use TMP instead of RAX? We must guarantee that | 40 // TODO(srdjan): Can we use TMP instead of RAX? We must guarantee that |
| 41 // TMP is never part of deoptimization environment. | 41 // TMP is never part of deoptimization environment. |
| 42 __ pushq(RAX); // Preserve RAX. | 42 __ pushq(RAX); // Preserve RAX. |
| 43 Label L; | 43 Label L; |
| (...skipping 1268 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1312 void ParallelMoveResolver::Exchange(const Address& mem1, const Address& mem2) { | 1312 void ParallelMoveResolver::Exchange(const Address& mem1, const Address& mem2) { |
| 1313 __ Exchange(mem1, mem2); | 1313 __ Exchange(mem1, mem2); |
| 1314 } | 1314 } |
| 1315 | 1315 |
| 1316 | 1316 |
| 1317 #undef __ | 1317 #undef __ |
| 1318 | 1318 |
| 1319 } // namespace dart | 1319 } // namespace dart |
| 1320 | 1320 |
| 1321 #endif // defined TARGET_ARCH_X64 | 1321 #endif // defined TARGET_ARCH_X64 |
| OLD | NEW |