Chromium Code Reviews| 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 95 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 106 graph_zone_, MachineType::PointerRepresentation(), | 106 graph_zone_, MachineType::PointerRepresentation(), |
| 107 InstructionSelector::SupportedMachineOperatorFlags(), | 107 InstructionSelector::SupportedMachineOperatorFlags(), |
| 108 InstructionSelector::AlignmentRequirements()); | 108 InstructionSelector::AlignmentRequirements()); |
| 109 common_ = new (graph_zone_) CommonOperatorBuilder(graph_zone_); | 109 common_ = new (graph_zone_) CommonOperatorBuilder(graph_zone_); |
| 110 javascript_ = new (graph_zone_) JSOperatorBuilder(graph_zone_); | 110 javascript_ = new (graph_zone_) JSOperatorBuilder(graph_zone_); |
| 111 jsgraph_ = new (graph_zone_) | 111 jsgraph_ = new (graph_zone_) |
| 112 JSGraph(isolate_, graph_, common_, javascript_, simplified_, machine_); | 112 JSGraph(isolate_, graph_, common_, javascript_, simplified_, machine_); |
| 113 } | 113 } |
| 114 | 114 |
| 115 // For WASM compile entry point. | 115 // For WASM compile entry point. |
| 116 PipelineData(ZoneStats* zone_stats, CompilationInfo* info, Graph* graph, | 116 PipelineData(ZoneStats* zone_stats, CompilationInfo* info, JSGraph* jsgraph, |
| 117 SourcePositionTable* source_positions) | 117 SourcePositionTable* source_positions) |
| 118 : isolate_(info->isolate()), | 118 : isolate_(info->isolate()), |
| 119 info_(info), | 119 info_(info), |
| 120 debug_name_(info_->GetDebugName()), | 120 debug_name_(info_->GetDebugName()), |
| 121 zone_stats_(zone_stats), | 121 zone_stats_(zone_stats), |
| 122 graph_zone_scope_(zone_stats_, ZONE_NAME), | 122 graph_zone_scope_(zone_stats_, ZONE_NAME), |
| 123 graph_(graph), | 123 graph_(jsgraph->graph()), |
| 124 source_positions_(source_positions), | 124 source_positions_(source_positions), |
| 125 machine_(jsgraph->machine()), | |
| 126 common_(jsgraph->common()), | |
| 127 javascript_(jsgraph->javascript()), | |
|
ahaas
2016/11/28 08:34:43
I think jsgraph->javascript() should always be nul
titzer
2016/11/28 09:31:53
I think that would just made the code brittle with
| |
| 128 jsgraph_(jsgraph), | |
| 125 instruction_zone_scope_(zone_stats_, ZONE_NAME), | 129 instruction_zone_scope_(zone_stats_, ZONE_NAME), |
| 126 instruction_zone_(instruction_zone_scope_.zone()), | 130 instruction_zone_(instruction_zone_scope_.zone()), |
| 127 register_allocation_zone_scope_(zone_stats_, ZONE_NAME), | 131 register_allocation_zone_scope_(zone_stats_, ZONE_NAME), |
| 128 register_allocation_zone_(register_allocation_zone_scope_.zone()) {} | 132 register_allocation_zone_(register_allocation_zone_scope_.zone()) {} |
| 129 | 133 |
| 130 // For machine graph testing entry point. | 134 // For machine graph testing entry point. |
| 131 PipelineData(ZoneStats* zone_stats, CompilationInfo* info, Graph* graph, | 135 PipelineData(ZoneStats* zone_stats, CompilationInfo* info, Graph* graph, |
| 132 Schedule* schedule) | 136 Schedule* schedule) |
| 133 : isolate_(info->isolate()), | 137 : isolate_(info->isolate()), |
| 134 info_(info), | 138 info_(info), |
| (...skipping 457 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 592 info()->SetCode(code); | 596 info()->SetCode(code); |
| 593 if (info()->is_deoptimization_enabled()) { | 597 if (info()->is_deoptimization_enabled()) { |
| 594 info()->context()->native_context()->AddOptimizedCode(*code); | 598 info()->context()->native_context()->AddOptimizedCode(*code); |
| 595 RegisterWeakObjectsInOptimizedCode(code); | 599 RegisterWeakObjectsInOptimizedCode(code); |
| 596 } | 600 } |
| 597 return SUCCEEDED; | 601 return SUCCEEDED; |
| 598 } | 602 } |
| 599 | 603 |
| 600 class PipelineWasmCompilationJob final : public CompilationJob { | 604 class PipelineWasmCompilationJob final : public CompilationJob { |
| 601 public: | 605 public: |
| 602 explicit PipelineWasmCompilationJob(CompilationInfo* info, Graph* graph, | 606 explicit PipelineWasmCompilationJob(CompilationInfo* info, JSGraph* jsgraph, |
| 603 CallDescriptor* descriptor, | 607 CallDescriptor* descriptor, |
| 604 SourcePositionTable* source_positions) | 608 SourcePositionTable* source_positions) |
| 605 : CompilationJob(info->isolate(), info, "TurboFan", | 609 : CompilationJob(info->isolate(), info, "TurboFan", |
| 606 State::kReadyToExecute), | 610 State::kReadyToExecute), |
| 607 zone_stats_(info->isolate()->allocator()), | 611 zone_stats_(info->isolate()->allocator()), |
| 608 data_(&zone_stats_, info, graph, source_positions), | 612 data_(&zone_stats_, info, jsgraph, source_positions), |
| 609 pipeline_(&data_), | 613 pipeline_(&data_), |
| 610 linkage_(descriptor) {} | 614 linkage_(descriptor) {} |
| 611 | 615 |
| 612 protected: | 616 protected: |
| 613 Status PrepareJobImpl() final; | 617 Status PrepareJobImpl() final; |
| 614 Status ExecuteJobImpl() final; | 618 Status ExecuteJobImpl() final; |
| 615 Status FinalizeJobImpl() final; | 619 Status FinalizeJobImpl() final; |
| 616 | 620 |
| 617 private: | 621 private: |
| 618 ZoneStats zone_stats_; | 622 ZoneStats zone_stats_; |
| (...skipping 10 matching lines...) Expand all Loading... | |
| 629 | 633 |
| 630 PipelineWasmCompilationJob::Status | 634 PipelineWasmCompilationJob::Status |
| 631 PipelineWasmCompilationJob::ExecuteJobImpl() { | 635 PipelineWasmCompilationJob::ExecuteJobImpl() { |
| 632 if (FLAG_trace_turbo) { | 636 if (FLAG_trace_turbo) { |
| 633 TurboJsonFile json_of(info(), std::ios_base::trunc); | 637 TurboJsonFile json_of(info(), std::ios_base::trunc); |
| 634 json_of << "{\"function\":\"" << info()->GetDebugName().get() | 638 json_of << "{\"function\":\"" << info()->GetDebugName().get() |
| 635 << "\", \"source\":\"\",\n\"phases\":["; | 639 << "\", \"source\":\"\",\n\"phases\":["; |
| 636 } | 640 } |
| 637 | 641 |
| 638 pipeline_.RunPrintAndVerify("Machine", true); | 642 pipeline_.RunPrintAndVerify("Machine", true); |
| 643 if (FLAG_wasm_opt) { | |
| 644 PipelineData* data = &data_; | |
| 645 PipelineRunScope scope(data, "WASM optimization"); | |
| 646 JSGraphReducer graph_reducer(data->jsgraph(), scope.zone()); | |
| 647 DeadCodeElimination dead_code_elimination(&graph_reducer, data->graph(), | |
| 648 data->common()); | |
| 649 ValueNumberingReducer value_numbering(scope.zone(), data->graph()->zone()); | |
| 650 MachineOperatorReducer machine_reducer(data->jsgraph()); | |
| 651 CommonOperatorReducer common_reducer(&graph_reducer, data->graph(), | |
| 652 data->common(), data->machine()); | |
| 653 AddReducer(data, &graph_reducer, &dead_code_elimination); | |
| 654 AddReducer(data, &graph_reducer, &value_numbering); | |
| 655 AddReducer(data, &graph_reducer, &machine_reducer); | |
| 656 AddReducer(data, &graph_reducer, &common_reducer); | |
| 657 graph_reducer.ReduceGraph(); | |
| 658 pipeline_.RunPrintAndVerify("Optimized Machine", true); | |
| 659 } | |
| 639 | 660 |
| 640 if (!pipeline_.ScheduleAndSelectInstructions(&linkage_, true)) return FAILED; | 661 if (!pipeline_.ScheduleAndSelectInstructions(&linkage_, true)) return FAILED; |
| 641 return SUCCEEDED; | 662 return SUCCEEDED; |
| 642 } | 663 } |
| 643 | 664 |
| 644 PipelineWasmCompilationJob::Status | 665 PipelineWasmCompilationJob::Status |
| 645 PipelineWasmCompilationJob::FinalizeJobImpl() { | 666 PipelineWasmCompilationJob::FinalizeJobImpl() { |
| 646 pipeline_.GenerateCode(&linkage_); | 667 pipeline_.GenerateCode(&linkage_); |
| 647 return SUCCEEDED; | 668 return SUCCEEDED; |
| 648 } | 669 } |
| (...skipping 1043 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1692 return pipeline.ScheduleAndGenerateCode(call_descriptor); | 1713 return pipeline.ScheduleAndGenerateCode(call_descriptor); |
| 1693 } | 1714 } |
| 1694 | 1715 |
| 1695 // static | 1716 // static |
| 1696 CompilationJob* Pipeline::NewCompilationJob(Handle<JSFunction> function) { | 1717 CompilationJob* Pipeline::NewCompilationJob(Handle<JSFunction> function) { |
| 1697 return new PipelineCompilationJob(function->GetIsolate(), function); | 1718 return new PipelineCompilationJob(function->GetIsolate(), function); |
| 1698 } | 1719 } |
| 1699 | 1720 |
| 1700 // static | 1721 // static |
| 1701 CompilationJob* Pipeline::NewWasmCompilationJob( | 1722 CompilationJob* Pipeline::NewWasmCompilationJob( |
| 1702 CompilationInfo* info, Graph* graph, CallDescriptor* descriptor, | 1723 CompilationInfo* info, JSGraph* jsgraph, CallDescriptor* descriptor, |
| 1703 SourcePositionTable* source_positions) { | 1724 SourcePositionTable* source_positions) { |
| 1704 return new PipelineWasmCompilationJob(info, graph, descriptor, | 1725 return new PipelineWasmCompilationJob(info, jsgraph, descriptor, |
| 1705 source_positions); | 1726 source_positions); |
| 1706 } | 1727 } |
| 1707 | 1728 |
| 1708 bool Pipeline::AllocateRegistersForTesting(const RegisterConfiguration* config, | 1729 bool Pipeline::AllocateRegistersForTesting(const RegisterConfiguration* config, |
| 1709 InstructionSequence* sequence, | 1730 InstructionSequence* sequence, |
| 1710 bool run_verifier) { | 1731 bool run_verifier) { |
| 1711 CompilationInfo info(ArrayVector("testing"), sequence->isolate(), | 1732 CompilationInfo info(ArrayVector("testing"), sequence->isolate(), |
| 1712 sequence->zone(), Code::ComputeFlags(Code::STUB)); | 1733 sequence->zone(), Code::ComputeFlags(Code::STUB)); |
| 1713 ZoneStats zone_stats(sequence->isolate()->allocator()); | 1734 ZoneStats zone_stats(sequence->isolate()->allocator()); |
| 1714 PipelineData data(&zone_stats, &info, sequence); | 1735 PipelineData data(&zone_stats, &info, sequence); |
| (...skipping 229 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1944 data->DeleteRegisterAllocationZone(); | 1965 data->DeleteRegisterAllocationZone(); |
| 1945 } | 1966 } |
| 1946 | 1967 |
| 1947 CompilationInfo* PipelineImpl::info() const { return data_->info(); } | 1968 CompilationInfo* PipelineImpl::info() const { return data_->info(); } |
| 1948 | 1969 |
| 1949 Isolate* PipelineImpl::isolate() const { return info()->isolate(); } | 1970 Isolate* PipelineImpl::isolate() const { return info()->isolate(); } |
| 1950 | 1971 |
| 1951 } // namespace compiler | 1972 } // namespace compiler |
| 1952 } // namespace internal | 1973 } // namespace internal |
| 1953 } // namespace v8 | 1974 } // namespace v8 |
| OLD | NEW |