Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 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/code-stubs.h" | 5 #include "src/code-stubs.h" |
| 6 | 6 |
| 7 #include <sstream> | 7 #include <sstream> |
| 8 | 8 |
| 9 #include "src/ast/ast.h" | 9 #include "src/ast/ast.h" |
| 10 #include "src/bootstrapper.h" | 10 #include "src/bootstrapper.h" |
| (...skipping 1079 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1090 } | 1090 } |
| 1091 } | 1091 } |
| 1092 | 1092 |
| 1093 assembler->Bind(&if_rhsisnotsmi); | 1093 assembler->Bind(&if_rhsisnotsmi); |
| 1094 { | 1094 { |
| 1095 // Load the map of {rhs}. | 1095 // Load the map of {rhs}. |
| 1096 Node* rhs_map = assembler->LoadMap(rhs); | 1096 Node* rhs_map = assembler->LoadMap(rhs); |
| 1097 | 1097 |
| 1098 // Check if the {rhs} is a HeapNumber. | 1098 // Check if the {rhs} is a HeapNumber. |
| 1099 assembler->GotoUnless(assembler->IsHeapNumberMap(rhs_map), | 1099 assembler->GotoUnless(assembler->IsHeapNumberMap(rhs_map), |
| 1100 &call_add_stub); | 1100 &call_add_stub); |
|
rmcilroy
2016/10/04 08:05:31
We also need a check here. My suggestion would be
Leszek Swirski
2016/10/04 08:30:40
Ah, this patch was only adding string + string = s
| |
| 1101 | 1101 |
| 1102 var_fadd_lhs.Bind(assembler->SmiToFloat64(lhs)); | 1102 var_fadd_lhs.Bind(assembler->SmiToFloat64(lhs)); |
| 1103 var_fadd_rhs.Bind(assembler->LoadHeapNumberValue(rhs)); | 1103 var_fadd_rhs.Bind(assembler->LoadHeapNumberValue(rhs)); |
| 1104 assembler->Goto(&do_fadd); | 1104 assembler->Goto(&do_fadd); |
| 1105 } | 1105 } |
| 1106 } | 1106 } |
| 1107 | 1107 |
| 1108 assembler->Bind(&if_lhsisnotsmi); | 1108 assembler->Bind(&if_lhsisnotsmi); |
| 1109 { | 1109 { |
| 1110 Label check_string(assembler); | |
| 1111 | |
| 1110 // Load the map of {lhs}. | 1112 // Load the map of {lhs}. |
| 1111 Node* lhs_map = assembler->LoadMap(lhs); | 1113 Node* lhs_map = assembler->LoadMap(lhs); |
| 1112 | 1114 |
| 1113 // Check if {lhs} is a HeapNumber. | 1115 // Check if {lhs} is a HeapNumber. |
| 1114 Label if_lhsisnumber(assembler), if_lhsisnotnumber(assembler); | 1116 Label if_lhsisnumber(assembler), if_lhsisnotnumber(assembler); |
| 1115 assembler->GotoUnless(assembler->IsHeapNumberMap(lhs_map), &call_add_stub); | 1117 assembler->GotoUnless(assembler->IsHeapNumberMap(lhs_map), &check_string); |
| 1116 | 1118 |
| 1117 // Check if the {rhs} is Smi. | 1119 // Check if the {rhs} is Smi. |
| 1118 Label if_rhsissmi(assembler), if_rhsisnotsmi(assembler); | 1120 Label if_rhsissmi(assembler), if_rhsisnotsmi(assembler); |
| 1119 assembler->Branch(assembler->WordIsSmi(rhs), &if_rhsissmi, &if_rhsisnotsmi); | 1121 assembler->Branch(assembler->WordIsSmi(rhs), &if_rhsissmi, &if_rhsisnotsmi); |
| 1120 | 1122 |
| 1121 assembler->Bind(&if_rhsissmi); | 1123 assembler->Bind(&if_rhsissmi); |
| 1122 { | 1124 { |
| 1123 var_fadd_lhs.Bind(assembler->LoadHeapNumberValue(lhs)); | 1125 var_fadd_lhs.Bind(assembler->LoadHeapNumberValue(lhs)); |
| 1124 var_fadd_rhs.Bind(assembler->SmiToFloat64(rhs)); | 1126 var_fadd_rhs.Bind(assembler->SmiToFloat64(rhs)); |
| 1125 assembler->Goto(&do_fadd); | 1127 assembler->Goto(&do_fadd); |
| 1126 } | 1128 } |
| 1127 | 1129 |
| 1128 assembler->Bind(&if_rhsisnotsmi); | 1130 assembler->Bind(&if_rhsisnotsmi); |
| 1129 { | 1131 { |
| 1130 // Load the map of {rhs}. | 1132 // Load the map of {rhs}. |
| 1131 Node* rhs_map = assembler->LoadMap(rhs); | 1133 Node* rhs_map = assembler->LoadMap(rhs); |
| 1132 | 1134 |
| 1133 // Check if the {rhs} is a HeapNumber. | 1135 // Check if the {rhs} is a HeapNumber. |
| 1134 assembler->GotoUnless(assembler->IsHeapNumberMap(rhs_map), | 1136 assembler->GotoUnless(assembler->IsHeapNumberMap(rhs_map), |
| 1135 &call_add_stub); | 1137 &call_add_stub); |
|
rmcilroy
2016/10/04 08:05:31
Same comment here as above - here you know that lh
Leszek Swirski
2016/10/04 08:30:40
As above.
| |
| 1136 | 1138 |
| 1137 var_fadd_lhs.Bind(assembler->LoadHeapNumberValue(lhs)); | 1139 var_fadd_lhs.Bind(assembler->LoadHeapNumberValue(lhs)); |
| 1138 var_fadd_rhs.Bind(assembler->LoadHeapNumberValue(rhs)); | 1140 var_fadd_rhs.Bind(assembler->LoadHeapNumberValue(rhs)); |
| 1139 assembler->Goto(&do_fadd); | 1141 assembler->Goto(&do_fadd); |
| 1140 } | 1142 } |
| 1143 | |
| 1144 assembler->Bind(&check_string); | |
| 1145 { | |
| 1146 // Check if the {rhs} is a smi, and exit the string check early if it is. | |
| 1147 assembler->GotoIf(assembler->WordIsSmi(rhs), &call_add_stub); | |
|
rmcilroy
2016/10/04 08:05:31
We should still count this as a string if the lhs
Leszek Swirski
2016/10/04 08:30:40
As above.
| |
| 1148 | |
| 1149 Node* lhs_instance_type = assembler->LoadMapInstanceType(lhs_map); | |
| 1150 | |
| 1151 assembler->GotoUnless(assembler->Int32LessThan( | |
| 1152 lhs_instance_type, | |
| 1153 assembler->Int32Constant(FIRST_NONSTRING_TYPE)), | |
| 1154 &call_add_stub); | |
| 1155 | |
| 1156 Node* rhs_instance_type = assembler->LoadInstanceType(rhs); | |
| 1157 | |
| 1158 assembler->GotoUnless(assembler->Int32LessThan( | |
| 1159 rhs_instance_type, | |
| 1160 assembler->Int32Constant(FIRST_NONSTRING_TYPE)), | |
| 1161 &call_add_stub); | |
| 1162 | |
| 1163 var_type_feedback.Bind( | |
| 1164 assembler->Int32Constant(BinaryOperationFeedback::kString)); | |
| 1165 Callable callable = CodeFactory::Add(assembler->isolate()); | |
| 1166 var_result.Bind(assembler->CallStub(callable, context, lhs, rhs)); | |
|
rmcilroy
2016/10/04 08:05:31
Let's keep the calling of the stub and updating of
Leszek Swirski
2016/10/04 08:30:40
Not sure about this, calling the stub is a small a
| |
| 1167 assembler->Goto(&end); | |
| 1168 } | |
| 1141 } | 1169 } |
| 1142 | 1170 |
| 1143 assembler->Bind(&do_fadd); | 1171 assembler->Bind(&do_fadd); |
| 1144 { | 1172 { |
| 1145 var_type_feedback.Bind( | 1173 var_type_feedback.Bind( |
| 1146 assembler->Int32Constant(BinaryOperationFeedback::kNumber)); | 1174 assembler->Int32Constant(BinaryOperationFeedback::kNumber)); |
| 1147 Node* value = | 1175 Node* value = |
| 1148 assembler->Float64Add(var_fadd_lhs.value(), var_fadd_rhs.value()); | 1176 assembler->Float64Add(var_fadd_lhs.value(), var_fadd_rhs.value()); |
| 1149 Node* result = assembler->ChangeFloat64ToTagged(value); | 1177 Node* result = assembler->ChangeFloat64ToTagged(value); |
| 1150 var_result.Bind(result); | 1178 var_result.Bind(result); |
| 1151 assembler->Goto(&end); | 1179 assembler->Goto(&end); |
| 1152 } | 1180 } |
| 1153 | 1181 |
| 1154 assembler->Bind(&call_add_stub); | 1182 assembler->Bind(&call_add_stub); |
| 1155 { | 1183 { |
| 1184 assembler->Comment("Calling the stub"); | |
| 1156 var_type_feedback.Bind( | 1185 var_type_feedback.Bind( |
| 1157 assembler->Int32Constant(BinaryOperationFeedback::kAny)); | 1186 assembler->Int32Constant(BinaryOperationFeedback::kAny)); |
| 1158 Callable callable = CodeFactory::Add(assembler->isolate()); | 1187 Callable callable = CodeFactory::Add(assembler->isolate()); |
| 1159 var_result.Bind(assembler->CallStub(callable, context, lhs, rhs)); | 1188 var_result.Bind(assembler->CallStub(callable, context, lhs, rhs)); |
| 1160 assembler->Goto(&end); | 1189 assembler->Goto(&end); |
| 1161 } | 1190 } |
| 1162 | 1191 |
| 1163 assembler->Bind(&end); | 1192 assembler->Bind(&end); |
| 1193 assembler->Comment("Updating the feedback"); | |
| 1164 assembler->UpdateFeedback(var_type_feedback.value(), type_feedback_vector, | 1194 assembler->UpdateFeedback(var_type_feedback.value(), type_feedback_vector, |
| 1165 slot_id); | 1195 slot_id); |
| 1166 return var_result.value(); | 1196 return var_result.value(); |
| 1167 } | 1197 } |
| 1168 | 1198 |
| 1169 // static | 1199 // static |
| 1170 compiler::Node* SubtractStub::Generate(CodeStubAssembler* assembler, | 1200 compiler::Node* SubtractStub::Generate(CodeStubAssembler* assembler, |
| 1171 compiler::Node* left, | 1201 compiler::Node* left, |
| 1172 compiler::Node* right, | 1202 compiler::Node* right, |
| 1173 compiler::Node* context) { | 1203 compiler::Node* context) { |
| (...skipping 4698 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 5872 | 5902 |
| 5873 if (type == MachineType::Pointer()) { | 5903 if (type == MachineType::Pointer()) { |
| 5874 return Representation::External(); | 5904 return Representation::External(); |
| 5875 } | 5905 } |
| 5876 | 5906 |
| 5877 return Representation::Tagged(); | 5907 return Representation::Tagged(); |
| 5878 } | 5908 } |
| 5879 | 5909 |
| 5880 } // namespace internal | 5910 } // namespace internal |
| 5881 } // namespace v8 | 5911 } // namespace v8 |
| OLD | NEW |