OLD | NEW |
1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "src/compiler/pipeline.h" | 5 #include "src/compiler/pipeline.h" |
6 | 6 |
7 #include <fstream> // NOLINT(readability/streams) | 7 #include <fstream> // NOLINT(readability/streams) |
8 #include <memory> | 8 #include <memory> |
9 #include <sstream> | 9 #include <sstream> |
10 | 10 |
(...skipping 597 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
608 if (!info()->is_optimizing_from_bytecode()) { | 608 if (!info()->is_optimizing_from_bytecode()) { |
609 if (FLAG_inline_accessors) { | 609 if (FLAG_inline_accessors) { |
610 info()->MarkAsAccessorInliningEnabled(); | 610 info()->MarkAsAccessorInliningEnabled(); |
611 } | 611 } |
612 if (info()->is_deoptimization_enabled() && FLAG_turbo_type_feedback) { | 612 if (info()->is_deoptimization_enabled() && FLAG_turbo_type_feedback) { |
613 info()->MarkAsTypeFeedbackEnabled(); | 613 info()->MarkAsTypeFeedbackEnabled(); |
614 } | 614 } |
615 if (!Compiler::EnsureDeoptimizationSupport(info())) return FAILED; | 615 if (!Compiler::EnsureDeoptimizationSupport(info())) return FAILED; |
616 } | 616 } |
617 | 617 |
618 // TODO(mstarzinger): Hack to ensure that certain call descriptors are | 618 // TODO(mstarzinger): Hack to ensure that the ToNumber call descriptor is |
619 // initialized on the main thread, since it is needed off-thread by the | 619 // initialized on the main thread, since it is needed off-thread by the |
620 // effect control linearizer. | 620 // effect control linearizer. |
621 CodeFactory::CopyFixedArray(info()->isolate()); | |
622 CodeFactory::ToNumber(info()->isolate()); | 621 CodeFactory::ToNumber(info()->isolate()); |
623 | 622 |
624 linkage_ = new (&zone_) Linkage(Linkage::ComputeIncoming(&zone_, info())); | 623 linkage_ = new (&zone_) Linkage(Linkage::ComputeIncoming(&zone_, info())); |
625 | 624 |
626 if (!pipeline_.CreateGraph()) { | 625 if (!pipeline_.CreateGraph()) { |
627 if (isolate()->has_pending_exception()) return FAILED; // Stack overflowed. | 626 if (isolate()->has_pending_exception()) return FAILED; // Stack overflowed. |
628 return AbortOptimization(kGraphBuildingFailed); | 627 return AbortOptimization(kGraphBuildingFailed); |
629 } | 628 } |
630 | 629 |
631 return SUCCEEDED; | 630 return SUCCEEDED; |
(...skipping 436 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1068 struct LoadEliminationPhase { | 1067 struct LoadEliminationPhase { |
1069 static const char* phase_name() { return "load elimination"; } | 1068 static const char* phase_name() { return "load elimination"; } |
1070 | 1069 |
1071 void Run(PipelineData* data, Zone* temp_zone) { | 1070 void Run(PipelineData* data, Zone* temp_zone) { |
1072 JSGraphReducer graph_reducer(data->jsgraph(), temp_zone); | 1071 JSGraphReducer graph_reducer(data->jsgraph(), temp_zone); |
1073 BranchElimination branch_condition_elimination(&graph_reducer, | 1072 BranchElimination branch_condition_elimination(&graph_reducer, |
1074 data->jsgraph(), temp_zone); | 1073 data->jsgraph(), temp_zone); |
1075 DeadCodeElimination dead_code_elimination(&graph_reducer, data->graph(), | 1074 DeadCodeElimination dead_code_elimination(&graph_reducer, data->graph(), |
1076 data->common()); | 1075 data->common()); |
1077 RedundancyElimination redundancy_elimination(&graph_reducer, temp_zone); | 1076 RedundancyElimination redundancy_elimination(&graph_reducer, temp_zone); |
1078 LoadElimination load_elimination(&graph_reducer, data->jsgraph(), | 1077 LoadElimination load_elimination(&graph_reducer, temp_zone); |
1079 temp_zone); | |
1080 ValueNumberingReducer value_numbering(temp_zone, data->graph()->zone()); | 1078 ValueNumberingReducer value_numbering(temp_zone, data->graph()->zone()); |
1081 CommonOperatorReducer common_reducer(&graph_reducer, data->graph(), | 1079 CommonOperatorReducer common_reducer(&graph_reducer, data->graph(), |
1082 data->common(), data->machine()); | 1080 data->common(), data->machine()); |
1083 AddReducer(data, &graph_reducer, &branch_condition_elimination); | 1081 AddReducer(data, &graph_reducer, &branch_condition_elimination); |
1084 AddReducer(data, &graph_reducer, &dead_code_elimination); | 1082 AddReducer(data, &graph_reducer, &dead_code_elimination); |
1085 AddReducer(data, &graph_reducer, &redundancy_elimination); | 1083 AddReducer(data, &graph_reducer, &redundancy_elimination); |
1086 AddReducer(data, &graph_reducer, &load_elimination); | 1084 AddReducer(data, &graph_reducer, &load_elimination); |
1087 AddReducer(data, &graph_reducer, &value_numbering); | 1085 AddReducer(data, &graph_reducer, &value_numbering); |
1088 AddReducer(data, &graph_reducer, &common_reducer); | 1086 AddReducer(data, &graph_reducer, &common_reducer); |
1089 graph_reducer.ReduceGraph(); | 1087 graph_reducer.ReduceGraph(); |
(...skipping 805 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1895 data->DeleteRegisterAllocationZone(); | 1893 data->DeleteRegisterAllocationZone(); |
1896 } | 1894 } |
1897 | 1895 |
1898 CompilationInfo* PipelineImpl::info() const { return data_->info(); } | 1896 CompilationInfo* PipelineImpl::info() const { return data_->info(); } |
1899 | 1897 |
1900 Isolate* PipelineImpl::isolate() const { return info()->isolate(); } | 1898 Isolate* PipelineImpl::isolate() const { return info()->isolate(); } |
1901 | 1899 |
1902 } // namespace compiler | 1900 } // namespace compiler |
1903 } // namespace internal | 1901 } // namespace internal |
1904 } // namespace v8 | 1902 } // namespace v8 |
OLD | NEW |