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/simplified-lowering.h" | 5 #include "src/compiler/simplified-lowering.h" |
6 | 6 |
7 #include <limits> | 7 #include <limits> |
8 | 8 |
9 #include "src/base/bits.h" | 9 #include "src/base/bits.h" |
10 #include "src/code-factory.h" | 10 #include "src/code-factory.h" |
(...skipping 1009 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1020 node->RemoveInput(2); | 1020 node->RemoveInput(2); |
1021 } else { | 1021 } else { |
1022 DCHECK_EQ(kTypedArrayBoundsCheck, access.bounds_check); | 1022 DCHECK_EQ(kTypedArrayBoundsCheck, access.bounds_check); |
1023 | 1023 |
1024 Node* base = node->InputAt(0); | 1024 Node* base = node->InputAt(0); |
1025 Node* length = node->InputAt(2); | 1025 Node* length = node->InputAt(2); |
1026 Node* effect = node->InputAt(3); | 1026 Node* effect = node->InputAt(3); |
1027 Node* control = node->InputAt(4); | 1027 Node* control = node->InputAt(4); |
1028 | 1028 |
1029 Node* check = graph()->NewNode(machine()->Uint32LessThan(), key, length); | 1029 Node* check = graph()->NewNode(machine()->Uint32LessThan(), key, length); |
1030 Node* branch = graph()->NewNode(common()->Branch(), check, control); | 1030 Node* branch = |
| 1031 graph()->NewNode(common()->Branch(BranchHint::kTrue), check, control); |
1031 | 1032 |
1032 Node* if_true = graph()->NewNode(common()->IfTrue(), branch); | 1033 Node* if_true = graph()->NewNode(common()->IfTrue(), branch); |
1033 Node* load = graph()->NewNode(op, base, index, effect, if_true); | 1034 Node* load = graph()->NewNode(op, base, index, effect, if_true); |
1034 Node* result = load; | 1035 Node* result = load; |
1035 if (output_type & kRepTagged) { | 1036 if (output_type & kRepTagged) { |
1036 // TODO(turbofan): This is ugly as hell! | 1037 // TODO(turbofan): This is ugly as hell! |
1037 SimplifiedOperatorBuilder simplified(graph()->zone()); | 1038 SimplifiedOperatorBuilder simplified(graph()->zone()); |
1038 RepresentationChanger changer(jsgraph(), &simplified, | 1039 RepresentationChanger changer(jsgraph(), &simplified, |
1039 graph()->zone()->isolate()); | 1040 graph()->zone()->isolate()); |
1040 result = changer.GetTaggedRepresentationFor(result, access.machine_type); | 1041 result = changer.GetTaggedRepresentationFor(result, access.machine_type); |
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1091 } else { | 1092 } else { |
1092 DCHECK_EQ(kTypedArrayBoundsCheck, access.bounds_check); | 1093 DCHECK_EQ(kTypedArrayBoundsCheck, access.bounds_check); |
1093 | 1094 |
1094 Node* base = node->InputAt(0); | 1095 Node* base = node->InputAt(0); |
1095 Node* length = node->InputAt(2); | 1096 Node* length = node->InputAt(2); |
1096 Node* value = node->InputAt(3); | 1097 Node* value = node->InputAt(3); |
1097 Node* effect = node->InputAt(4); | 1098 Node* effect = node->InputAt(4); |
1098 Node* control = node->InputAt(5); | 1099 Node* control = node->InputAt(5); |
1099 | 1100 |
1100 Node* check = graph()->NewNode(machine()->Uint32LessThan(), key, length); | 1101 Node* check = graph()->NewNode(machine()->Uint32LessThan(), key, length); |
1101 Node* branch = graph()->NewNode(common()->Branch(), check, control); | 1102 Node* branch = |
| 1103 graph()->NewNode(common()->Branch(BranchHint::kTrue), check, control); |
1102 | 1104 |
1103 Node* if_true = graph()->NewNode(common()->IfTrue(), branch); | 1105 Node* if_true = graph()->NewNode(common()->IfTrue(), branch); |
1104 Node* store = graph()->NewNode(op, base, index, value, effect, if_true); | 1106 Node* store = graph()->NewNode(op, base, index, value, effect, if_true); |
1105 | 1107 |
1106 Node* if_false = graph()->NewNode(common()->IfFalse(), branch); | 1108 Node* if_false = graph()->NewNode(common()->IfFalse(), branch); |
1107 | 1109 |
1108 Node* merge = graph()->NewNode(common()->Merge(2), if_true, if_false); | 1110 Node* merge = graph()->NewNode(common()->Merge(2), if_true, if_false); |
1109 | 1111 |
1110 node->set_op(common()->EffectPhi(2)); | 1112 node->set_op(common()->EffectPhi(2)); |
1111 node->ReplaceInput(0, store); | 1113 node->ReplaceInput(0, store); |
(...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1166 void SimplifiedLowering::DoStringLessThanOrEqual(Node* node) { | 1168 void SimplifiedLowering::DoStringLessThanOrEqual(Node* node) { |
1167 node->set_op(machine()->IntLessThanOrEqual()); | 1169 node->set_op(machine()->IntLessThanOrEqual()); |
1168 node->ReplaceInput(0, StringComparison(node, true)); | 1170 node->ReplaceInput(0, StringComparison(node, true)); |
1169 node->ReplaceInput(1, jsgraph()->SmiConstant(EQUAL)); | 1171 node->ReplaceInput(1, jsgraph()->SmiConstant(EQUAL)); |
1170 } | 1172 } |
1171 | 1173 |
1172 | 1174 |
1173 } // namespace compiler | 1175 } // namespace compiler |
1174 } // namespace internal | 1176 } // namespace internal |
1175 } // namespace v8 | 1177 } // namespace v8 |
OLD | NEW |