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/gap-resolver.h" | 5 #include "src/compiler/gap-resolver.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <functional> | 8 #include <functional> |
9 #include <set> | 9 #include <set> |
10 | 10 |
(...skipping 57 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
68 } | 68 } |
69 } | 69 } |
70 | 70 |
71 // We are about to resolve this move and don't need it marked as pending, so | 71 // We are about to resolve this move and don't need it marked as pending, so |
72 // restore its destination. | 72 // restore its destination. |
73 move->set_destination(destination); | 73 move->set_destination(destination); |
74 | 74 |
75 // This move's source may have changed due to swaps to resolve cycles and so | 75 // This move's source may have changed due to swaps to resolve cycles and so |
76 // it may now be the last move in the cycle. If so remove it. | 76 // it may now be the last move in the cycle. If so remove it. |
77 InstructionOperand source = move->source(); | 77 InstructionOperand source = move->source(); |
78 if (source.EqualsModuloType(destination)) { | 78 if (source.EqualsCanonicalized(destination)) { |
79 move->Eliminate(); | 79 move->Eliminate(); |
80 return; | 80 return; |
81 } | 81 } |
82 | 82 |
83 // The move may be blocked on a (at most one) pending move, in which case we | 83 // The move may be blocked on a (at most one) pending move, in which case we |
84 // have a cycle. Search for such a blocking move and perform a swap to | 84 // have a cycle. Search for such a blocking move and perform a swap to |
85 // resolve it. | 85 // resolve it. |
86 auto blocker = std::find_if(moves->begin(), moves->end(), | 86 auto blocker = std::find_if(moves->begin(), moves->end(), |
87 std::bind2nd(std::ptr_fun(&Blocks), destination)); | 87 std::bind2nd(std::ptr_fun(&Blocks), destination)); |
88 if (blocker == moves->end()) { | 88 if (blocker == moves->end()) { |
(...skipping 18 matching lines...) Expand all Loading... |
107 if (other->Blocks(source)) { | 107 if (other->Blocks(source)) { |
108 other->set_source(destination); | 108 other->set_source(destination); |
109 } else if (other->Blocks(destination)) { | 109 } else if (other->Blocks(destination)) { |
110 other->set_source(source); | 110 other->set_source(source); |
111 } | 111 } |
112 } | 112 } |
113 } | 113 } |
114 } // namespace compiler | 114 } // namespace compiler |
115 } // namespace internal | 115 } // namespace internal |
116 } // namespace v8 | 116 } // namespace v8 |
OLD | NEW |