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 <sstream> | 8 #include <sstream> |
9 | 9 |
10 #include "src/base/adapters.h" | 10 #include "src/base/adapters.h" |
(...skipping 864 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
875 JSCreateLowering create_lowering( | 875 JSCreateLowering create_lowering( |
876 &graph_reducer, data->info()->dependencies(), data->jsgraph(), | 876 &graph_reducer, data->info()->dependencies(), data->jsgraph(), |
877 literals_array, temp_zone); | 877 literals_array, temp_zone); |
878 JSTypedLowering::Flags typed_lowering_flags = JSTypedLowering::kNoFlags; | 878 JSTypedLowering::Flags typed_lowering_flags = JSTypedLowering::kNoFlags; |
879 if (data->info()->is_deoptimization_enabled()) { | 879 if (data->info()->is_deoptimization_enabled()) { |
880 typed_lowering_flags |= JSTypedLowering::kDeoptimizationEnabled; | 880 typed_lowering_flags |= JSTypedLowering::kDeoptimizationEnabled; |
881 } | 881 } |
882 if (data->info()->shared_info()->HasBytecodeArray()) { | 882 if (data->info()->shared_info()->HasBytecodeArray()) { |
883 typed_lowering_flags |= JSTypedLowering::kDisableBinaryOpReduction; | 883 typed_lowering_flags |= JSTypedLowering::kDisableBinaryOpReduction; |
884 } | 884 } |
885 if (FLAG_turbo_type_feedback) { | |
Benedikt Meurer
2016/05/30 18:39:50
Can you add a CompilationInfo flag for this?
Jarin
2016/05/31 20:28:53
Done.
| |
886 typed_lowering_flags |= JSTypedLowering::kTypeFeedbackEnabled; | |
887 } | |
885 JSTypedLowering typed_lowering(&graph_reducer, data->info()->dependencies(), | 888 JSTypedLowering typed_lowering(&graph_reducer, data->info()->dependencies(), |
886 typed_lowering_flags, data->jsgraph(), | 889 typed_lowering_flags, data->jsgraph(), |
887 temp_zone); | 890 temp_zone); |
888 JSIntrinsicLowering intrinsic_lowering( | 891 JSIntrinsicLowering intrinsic_lowering( |
889 &graph_reducer, data->jsgraph(), | 892 &graph_reducer, data->jsgraph(), |
890 data->info()->is_deoptimization_enabled() | 893 data->info()->is_deoptimization_enabled() |
891 ? JSIntrinsicLowering::kDeoptimizationEnabled | 894 ? JSIntrinsicLowering::kDeoptimizationEnabled |
892 : JSIntrinsicLowering::kDeoptimizationDisabled); | 895 : JSIntrinsicLowering::kDeoptimizationDisabled); |
893 SimplifiedOperatorReducer simple_reducer(data->jsgraph()); | 896 SimplifiedOperatorReducer simple_reducer(data->jsgraph()); |
894 CommonOperatorReducer common_reducer(&graph_reducer, data->graph(), | 897 CommonOperatorReducer common_reducer(&graph_reducer, data->graph(), |
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
937 AddReducer(data, &graph_reducer, &escape_reducer); | 940 AddReducer(data, &graph_reducer, &escape_reducer); |
938 graph_reducer.ReduceGraph(); | 941 graph_reducer.ReduceGraph(); |
939 escape_reducer.VerifyReplacement(); | 942 escape_reducer.VerifyReplacement(); |
940 } | 943 } |
941 }; | 944 }; |
942 | 945 |
943 struct RepresentationSelectionPhase { | 946 struct RepresentationSelectionPhase { |
944 static const char* phase_name() { return "representation selection"; } | 947 static const char* phase_name() { return "representation selection"; } |
945 | 948 |
946 void Run(PipelineData* data, Zone* temp_zone) { | 949 void Run(PipelineData* data, Zone* temp_zone) { |
950 SimplifiedLowering::Flags flags = | |
951 FLAG_turbo_type_feedback ? SimplifiedLowering::kTypeFeedbackEnabled | |
Benedikt Meurer
2016/05/30 18:39:50
See comment above.
| |
952 : SimplifiedLowering::kNoFlag; | |
947 SimplifiedLowering lowering(data->jsgraph(), temp_zone, | 953 SimplifiedLowering lowering(data->jsgraph(), temp_zone, |
948 data->source_positions()); | 954 data->source_positions(), flags); |
949 lowering.LowerAllNodes(); | 955 lowering.LowerAllNodes(); |
950 } | 956 } |
951 }; | 957 }; |
952 | 958 |
953 struct EarlyOptimizationPhase { | 959 struct EarlyOptimizationPhase { |
954 static const char* phase_name() { return "early optimization"; } | 960 static const char* phase_name() { return "early optimization"; } |
955 | 961 |
956 void Run(PipelineData* data, Zone* temp_zone) { | 962 void Run(PipelineData* data, Zone* temp_zone) { |
957 JSGraphReducer graph_reducer(data->jsgraph(), temp_zone); | 963 JSGraphReducer graph_reducer(data->jsgraph(), temp_zone); |
958 JSGenericLowering generic_lowering(data->jsgraph()); | 964 JSGenericLowering generic_lowering(data->jsgraph()); |
(...skipping 837 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1796 data->DeleteRegisterAllocationZone(); | 1802 data->DeleteRegisterAllocationZone(); |
1797 } | 1803 } |
1798 | 1804 |
1799 CompilationInfo* PipelineImpl::info() const { return data_->info(); } | 1805 CompilationInfo* PipelineImpl::info() const { return data_->info(); } |
1800 | 1806 |
1801 Isolate* PipelineImpl::isolate() const { return info()->isolate(); } | 1807 Isolate* PipelineImpl::isolate() const { return info()->isolate(); } |
1802 | 1808 |
1803 } // namespace compiler | 1809 } // namespace compiler |
1804 } // namespace internal | 1810 } // namespace internal |
1805 } // namespace v8 | 1811 } // namespace v8 |
OLD | NEW |