| 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/compiler.h" | 5 #include "vm/compiler.h" |
| 6 | 6 |
| 7 #include "vm/assembler.h" | 7 #include "vm/assembler.h" |
| 8 #include "vm/ast_printer.h" | 8 #include "vm/ast_printer.h" |
| 9 #include "vm/code_generator.h" | 9 #include "vm/code_generator.h" |
| 10 #include "vm/code_patcher.h" | 10 #include "vm/code_patcher.h" |
| 11 #include "vm/dart_entry.h" | 11 #include "vm/dart_entry.h" |
| 12 #include "vm/debugger.h" | 12 #include "vm/debugger.h" |
| 13 #include "vm/disassembler.h" | 13 #include "vm/disassembler.h" |
| 14 #include "vm/exceptions.h" | 14 #include "vm/exceptions.h" |
| 15 #include "vm/flags.h" | 15 #include "vm/flags.h" |
| 16 #include "vm/flow_graph_allocator.h" | 16 #include "vm/flow_graph_allocator.h" |
| 17 #include "vm/flow_graph_builder.h" | 17 #include "vm/flow_graph_builder.h" |
| 18 #include "vm/flow_graph_compiler.h" | 18 #include "vm/flow_graph_compiler.h" |
| 19 #include "vm/flow_graph_optimizer.h" | 19 #include "vm/flow_graph_optimizer.h" |
| 20 #include "vm/il_printer.h" |
| 20 #include "vm/longjump.h" | 21 #include "vm/longjump.h" |
| 21 #include "vm/object.h" | 22 #include "vm/object.h" |
| 22 #include "vm/object_store.h" | 23 #include "vm/object_store.h" |
| 23 #include "vm/os.h" | 24 #include "vm/os.h" |
| 24 #include "vm/parser.h" | 25 #include "vm/parser.h" |
| 25 #include "vm/scanner.h" | 26 #include "vm/scanner.h" |
| 26 #include "vm/timer.h" | 27 #include "vm/timer.h" |
| 27 | 28 |
| 28 namespace dart { | 29 namespace dart { |
| 29 | 30 |
| (...skipping 131 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 161 intptr_t length = graph_builder.postorder_block_entries().length(); | 162 intptr_t length = graph_builder.postorder_block_entries().length(); |
| 162 for (intptr_t i = length - 1; i >= 0; --i) { | 163 for (intptr_t i = length - 1; i >= 0; --i) { |
| 163 block_order.Add(graph_builder.postorder_block_entries()[i]); | 164 block_order.Add(graph_builder.postorder_block_entries()[i]); |
| 164 } | 165 } |
| 165 if (optimized) { | 166 if (optimized) { |
| 166 FlowGraphOptimizer optimizer(block_order); | 167 FlowGraphOptimizer optimizer(block_order); |
| 167 optimizer.ApplyICData(); | 168 optimizer.ApplyICData(); |
| 168 | 169 |
| 169 if (use_ssa) { | 170 if (use_ssa) { |
| 170 // Perform register allocation on the SSA graph. | 171 // Perform register allocation on the SSA graph. |
| 171 FlowGraphAllocator allocator(graph_builder.postorder_block_entries(), | 172 FlowGraphAllocator allocator(block_order, &graph_builder); |
| 172 graph_builder.current_ssa_temp_index()); | 173 allocator.AllocateRegisters(); |
| 173 allocator.ResolveConstraints(); | |
| 174 allocator.AnalyzeLiveness(); | |
| 175 | |
| 176 // Temporary bailout until we support code generation from SSA form. | |
| 177 graph_builder.Bailout("No SSA code generation support."); | |
| 178 } | 174 } |
| 179 } | 175 } |
| 180 } | 176 } |
| 181 | 177 |
| 182 bool is_leaf = false; | 178 bool is_leaf = false; |
| 183 if (optimized) { | 179 if (optimized) { |
| 184 FlowGraphAnalyzer analyzer(block_order); | 180 FlowGraphAnalyzer analyzer(block_order); |
| 185 analyzer.Analyze(); | 181 analyzer.Analyze(); |
| 186 is_leaf = analyzer.is_leaf(); | 182 is_leaf = analyzer.is_leaf(); |
| 187 } | 183 } |
| 188 Assembler assembler; | 184 Assembler assembler; |
| 189 FlowGraphCompiler graph_compiler(&assembler, parsed_function, | 185 FlowGraphCompiler graph_compiler(&assembler, |
| 190 block_order, optimized, is_leaf); | 186 parsed_function, |
| 187 block_order, |
| 188 optimized, |
| 189 optimized && use_ssa, |
| 190 is_leaf); |
| 191 { | 191 { |
| 192 TimerScope timer(FLAG_compiler_stats, | 192 TimerScope timer(FLAG_compiler_stats, |
| 193 &CompilerStats::graphcompiler_timer, | 193 &CompilerStats::graphcompiler_timer, |
| 194 isolate); | 194 isolate); |
| 195 graph_compiler.CompileGraph(); | 195 graph_compiler.CompileGraph(); |
| 196 } | 196 } |
| 197 { | 197 { |
| 198 TimerScope timer(FLAG_compiler_stats, | 198 TimerScope timer(FLAG_compiler_stats, |
| 199 &CompilerStats::codefinalizer_timer, | 199 &CompilerStats::codefinalizer_timer, |
| 200 isolate); | 200 isolate); |
| (...skipping 275 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 476 isolate->object_store()->clear_sticky_error(); | 476 isolate->object_store()->clear_sticky_error(); |
| 477 isolate->set_long_jump_base(base); | 477 isolate->set_long_jump_base(base); |
| 478 return result.raw(); | 478 return result.raw(); |
| 479 } | 479 } |
| 480 UNREACHABLE(); | 480 UNREACHABLE(); |
| 481 return Object::null(); | 481 return Object::null(); |
| 482 } | 482 } |
| 483 | 483 |
| 484 | 484 |
| 485 } // namespace dart | 485 } // namespace dart |
| OLD | NEW |