| 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/v8.h" | 5 #include "src/v8.h" |
| 6 #include "test/cctest/cctest.h" | 6 #include "test/cctest/cctest.h" |
| 7 | 7 |
| 8 #include "src/compiler/common-operator.h" | 8 #include "src/compiler/common-operator.h" |
| 9 #include "src/compiler/graph-inl.h" | 9 #include "src/compiler/graph-inl.h" |
| 10 #include "src/compiler/phi-reducer.h" | 10 #include "src/compiler/phi-reducer.h" |
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 46 | 46 |
| 47 Node* Float64Constant(double val) { | 47 Node* Float64Constant(double val) { |
| 48 return graph.NewNode(common.Float64Constant(val)); | 48 return graph.NewNode(common.Float64Constant(val)); |
| 49 } | 49 } |
| 50 | 50 |
| 51 Node* Parameter(int32_t index = 0) { | 51 Node* Parameter(int32_t index = 0) { |
| 52 return graph.NewNode(common.Parameter(index), graph.start()); | 52 return graph.NewNode(common.Parameter(index), graph.start()); |
| 53 } | 53 } |
| 54 | 54 |
| 55 Node* Phi(Node* a) { | 55 Node* Phi(Node* a) { |
| 56 return SetSelfReferences(graph.NewNode(common.Phi(1), a)); | 56 return SetSelfReferences(graph.NewNode(common.Phi(kMachAnyTagged, 1), a)); |
| 57 } | 57 } |
| 58 | 58 |
| 59 Node* Phi(Node* a, Node* b) { | 59 Node* Phi(Node* a, Node* b) { |
| 60 return SetSelfReferences(graph.NewNode(common.Phi(2), a, b)); | 60 return SetSelfReferences( |
| 61 graph.NewNode(common.Phi(kMachAnyTagged, 2), a, b)); |
| 61 } | 62 } |
| 62 | 63 |
| 63 Node* Phi(Node* a, Node* b, Node* c) { | 64 Node* Phi(Node* a, Node* b, Node* c) { |
| 64 return SetSelfReferences(graph.NewNode(common.Phi(3), a, b, c)); | 65 return SetSelfReferences( |
| 66 graph.NewNode(common.Phi(kMachAnyTagged, 3), a, b, c)); |
| 65 } | 67 } |
| 66 | 68 |
| 67 Node* Phi(Node* a, Node* b, Node* c, Node* d) { | 69 Node* Phi(Node* a, Node* b, Node* c, Node* d) { |
| 68 return SetSelfReferences(graph.NewNode(common.Phi(4), a, b, c, d)); | 70 return SetSelfReferences( |
| 71 graph.NewNode(common.Phi(kMachAnyTagged, 4), a, b, c, d)); |
| 69 } | 72 } |
| 70 | 73 |
| 71 Node* PhiWithControl(Node* a, Node* control) { | 74 Node* PhiWithControl(Node* a, Node* control) { |
| 72 return SetSelfReferences(graph.NewNode(common.Phi(1), a, control)); | 75 return SetSelfReferences( |
| 76 graph.NewNode(common.Phi(kMachAnyTagged, 1), a, control)); |
| 73 } | 77 } |
| 74 | 78 |
| 75 Node* PhiWithControl(Node* a, Node* b, Node* control) { | 79 Node* PhiWithControl(Node* a, Node* b, Node* control) { |
| 76 return SetSelfReferences(graph.NewNode(common.Phi(2), a, b, control)); | 80 return SetSelfReferences( |
| 81 graph.NewNode(common.Phi(kMachAnyTagged, 2), a, b, control)); |
| 77 } | 82 } |
| 78 | 83 |
| 79 Node* SetSelfReferences(Node* node) { | 84 Node* SetSelfReferences(Node* node) { |
| 80 Node::Inputs inputs = node->inputs(); | 85 Node::Inputs inputs = node->inputs(); |
| 81 for (Node::Inputs::iterator iter(inputs.begin()); iter != inputs.end(); | 86 for (Node::Inputs::iterator iter(inputs.begin()); iter != inputs.end(); |
| 82 ++iter) { | 87 ++iter) { |
| 83 Node* input = *iter; | 88 Node* input = *iter; |
| 84 if (input == self) node->ReplaceInput(iter.index(), node); | 89 if (input == self) node->ReplaceInput(iter.index(), node); |
| 85 } | 90 } |
| 86 return node; | 91 return node; |
| (...skipping 129 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 216 Node* oneish = R.Float64Constant(1.1); | 221 Node* oneish = R.Float64Constant(1.1); |
| 217 Node* param = R.Parameter(); | 222 Node* param = R.Parameter(); |
| 218 | 223 |
| 219 Node* singles[] = {zero, one, oneish, param}; | 224 Node* singles[] = {zero, one, oneish, param}; |
| 220 for (size_t i = 0; i < arraysize(singles); ++i) { | 225 for (size_t i = 0; i < arraysize(singles); ++i) { |
| 221 R.CheckReduce(singles[i], R.PhiWithControl(singles[i], R.dead)); | 226 R.CheckReduce(singles[i], R.PhiWithControl(singles[i], R.dead)); |
| 222 R.CheckReduce(singles[i], R.PhiWithControl(R.self, singles[i], R.dead)); | 227 R.CheckReduce(singles[i], R.PhiWithControl(R.self, singles[i], R.dead)); |
| 223 R.CheckReduce(singles[i], R.PhiWithControl(singles[i], R.self, R.dead)); | 228 R.CheckReduce(singles[i], R.PhiWithControl(singles[i], R.self, R.dead)); |
| 224 } | 229 } |
| 225 } | 230 } |
| OLD | NEW |