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 | 8 |
9 #include "vm/ast_printer.h" | 9 #include "vm/ast_printer.h" |
10 #include "vm/block_scheduler.h" | 10 #include "vm/block_scheduler.h" |
(...skipping 873 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
884 DEBUG_ASSERT(flow_graph->VerifyUseLists()); | 884 DEBUG_ASSERT(flow_graph->VerifyUseLists()); |
885 // Canonicalization introduced more opportunities for constant | 885 // Canonicalization introduced more opportunities for constant |
886 // propagation. | 886 // propagation. |
887 ConstantPropagator::Optimize(flow_graph); | 887 ConstantPropagator::Optimize(flow_graph); |
888 DEBUG_ASSERT(flow_graph->VerifyUseLists()); | 888 DEBUG_ASSERT(flow_graph->VerifyUseLists()); |
889 } | 889 } |
890 | 890 |
891 // Optimistically convert loop phis that have a single non-smi input | 891 // Optimistically convert loop phis that have a single non-smi input |
892 // coming from the loop pre-header into smi-phis. | 892 // coming from the loop pre-header into smi-phis. |
893 if (FLAG_loop_invariant_code_motion) { | 893 if (FLAG_loop_invariant_code_motion) { |
894 flow_graph->FixupRedefinitions(); | |
895 DEBUG_ASSERT(flow_graph->VerifyRedefinitions()); | |
894 LICM licm(flow_graph); | 896 LICM licm(flow_graph); |
895 licm.OptimisticallySpecializeSmiPhis(); | 897 licm.OptimisticallySpecializeSmiPhis(); |
Vyacheslav Egorov (Google)
2017/02/23 13:47:27
I think we don't need to fixup redefinitions here
Florian Schneider
2017/02/23 19:26:35
Done.
| |
896 DEBUG_ASSERT(flow_graph->VerifyUseLists()); | 898 DEBUG_ASSERT(flow_graph->VerifyUseLists()); |
897 } | 899 } |
898 | 900 |
899 // Propagate types and eliminate even more type tests. | 901 // Propagate types and eliminate even more type tests. |
900 // Recompute types after constant propagation to infer more precise | 902 // Recompute types after constant propagation to infer more precise |
901 // types for uses that were previously reached by now eliminated phis. | 903 // types for uses that were previously reached by now eliminated phis. |
902 FlowGraphTypePropagator::Propagate(flow_graph); | 904 FlowGraphTypePropagator::Propagate(flow_graph); |
903 DEBUG_ASSERT(flow_graph->VerifyUseLists()); | 905 DEBUG_ASSERT(flow_graph->VerifyUseLists()); |
904 | 906 |
905 { | 907 { |
(...skipping 12 matching lines...) Expand all Loading... | |
918 | 920 |
919 { | 921 { |
920 NOT_IN_PRODUCT(TimelineDurationScope tds2( | 922 NOT_IN_PRODUCT(TimelineDurationScope tds2( |
921 thread(), compiler_timeline, "CommonSubexpressionElinination")); | 923 thread(), compiler_timeline, "CommonSubexpressionElinination")); |
922 if (FLAG_common_subexpression_elimination || | 924 if (FLAG_common_subexpression_elimination || |
923 FLAG_loop_invariant_code_motion) { | 925 FLAG_loop_invariant_code_motion) { |
924 flow_graph->ComputeBlockEffects(); | 926 flow_graph->ComputeBlockEffects(); |
925 } | 927 } |
926 | 928 |
927 if (FLAG_common_subexpression_elimination) { | 929 if (FLAG_common_subexpression_elimination) { |
928 if (DominatorBasedCSE::Optimize(flow_graph)) { | 930 if (DominatorBasedCSE::Optimize(flow_graph)) { |
Vyacheslav Egorov (Google)
2017/02/23 13:47:26
We do load forwarding here so we might introduce n
Florian Schneider
2017/02/23 19:26:35
Done.
| |
929 DEBUG_ASSERT(flow_graph->VerifyUseLists()); | 931 DEBUG_ASSERT(flow_graph->VerifyUseLists()); |
930 flow_graph->Canonicalize(); | 932 flow_graph->Canonicalize(); |
931 // Do another round of CSE to take secondary effects into account: | 933 // Do another round of CSE to take secondary effects into account: |
932 // e.g. when eliminating dependent loads (a.x[0] + a.x[0]) | 934 // e.g. when eliminating dependent loads (a.x[0] + a.x[0]) |
933 // TODO(fschneider): Change to a one-pass optimization pass. | 935 // TODO(fschneider): Change to a one-pass optimization pass. |
934 if (DominatorBasedCSE::Optimize(flow_graph)) { | 936 if (DominatorBasedCSE::Optimize(flow_graph)) { |
935 flow_graph->Canonicalize(); | 937 flow_graph->Canonicalize(); |
936 } | 938 } |
937 DEBUG_ASSERT(flow_graph->VerifyUseLists()); | 939 DEBUG_ASSERT(flow_graph->VerifyUseLists()); |
938 } | 940 } |
939 } | 941 } |
940 | 942 |
941 // Run loop-invariant code motion right after load elimination since | 943 // Run loop-invariant code motion right after load elimination since |
942 // it depends on the numbering of loads from the previous | 944 // it depends on the numbering of loads from the previous |
943 // load-elimination. | 945 // load-elimination. |
944 if (FLAG_loop_invariant_code_motion) { | 946 if (FLAG_loop_invariant_code_motion) { |
945 LICM licm(flow_graph); | 947 LICM licm(flow_graph); |
Vyacheslav Egorov (Google)
2017/02/23 13:47:27
I think we should fixup redefinitions here.
Florian Schneider
2017/02/23 19:26:35
Done.
| |
946 licm.Optimize(); | 948 licm.Optimize(); |
947 DEBUG_ASSERT(flow_graph->VerifyUseLists()); | 949 DEBUG_ASSERT(flow_graph->VerifyUseLists()); |
948 } | 950 } |
949 flow_graph->RemoveRedefinitions(); | 951 flow_graph->RemoveRedefinitions(); |
950 } | 952 } |
951 | 953 |
952 // Optimize (a << b) & c patterns, merge operations. | 954 // Optimize (a << b) & c patterns, merge operations. |
953 // Run after CSE in order to have more opportunity to merge | 955 // Run after CSE in order to have more opportunity to merge |
954 // instructions that have same inputs. | 956 // instructions that have same inputs. |
955 flow_graph->TryOptimizePatterns(); | 957 flow_graph->TryOptimizePatterns(); |
(...skipping 1309 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
2265 | 2267 |
2266 | 2268 |
2267 bool BackgroundCompiler::IsDisabled() { | 2269 bool BackgroundCompiler::IsDisabled() { |
2268 UNREACHABLE(); | 2270 UNREACHABLE(); |
2269 return true; | 2271 return true; |
2270 } | 2272 } |
2271 | 2273 |
2272 #endif // DART_PRECOMPILED_RUNTIME | 2274 #endif // DART_PRECOMPILED_RUNTIME |
2273 | 2275 |
2274 } // namespace dart | 2276 } // namespace dart |
OLD | NEW |