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 |