OLD | NEW |
1 // Copyright 2016 the V8 project authors. All rights reserved. | 1 // Copyright 2016 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/js-create-lowering.h" | 5 #include "src/compiler/js-create-lowering.h" |
6 | 6 |
7 #include "src/allocation-site-scopes.h" | 7 #include "src/allocation-site-scopes.h" |
8 #include "src/code-factory.h" | 8 #include "src/code-factory.h" |
9 #include "src/compilation-dependencies.h" | 9 #include "src/compilation-dependencies.h" |
10 #include "src/compiler/access-builder.h" | 10 #include "src/compiler/access-builder.h" |
(...skipping 751 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
762 int const function_map_index = | 762 int const function_map_index = |
763 Context::FunctionMapIndex(shared->language_mode(), shared->kind()); | 763 Context::FunctionMapIndex(shared->language_mode(), shared->kind()); |
764 Node* function_map = jsgraph()->HeapConstant( | 764 Node* function_map = jsgraph()->HeapConstant( |
765 handle(Map::cast(native_context()->get(function_map_index)), isolate())); | 765 handle(Map::cast(native_context()->get(function_map_index)), isolate())); |
766 | 766 |
767 // Note that it is only safe to embed the raw entry point of the compile | 767 // Note that it is only safe to embed the raw entry point of the compile |
768 // lazy stub into the code, because that stub is immortal and immovable. | 768 // lazy stub into the code, because that stub is immortal and immovable. |
769 Node* compile_entry = jsgraph()->PointerConstant( | 769 Node* compile_entry = jsgraph()->PointerConstant( |
770 jsgraph()->isolate()->builtins()->CompileLazy()->entry()); | 770 jsgraph()->isolate()->builtins()->CompileLazy()->entry()); |
771 Node* empty_fixed_array = jsgraph()->EmptyFixedArrayConstant(); | 771 Node* empty_fixed_array = jsgraph()->EmptyFixedArrayConstant(); |
772 Node* empty_literals_array = jsgraph()->EmptyLiteralsArrayConstant(); | 772 Node* empty_feedback_vector = jsgraph()->EmptyFeedbackVectorConstant(); |
773 Node* the_hole = jsgraph()->TheHoleConstant(); | 773 Node* the_hole = jsgraph()->TheHoleConstant(); |
774 Node* undefined = jsgraph()->UndefinedConstant(); | 774 Node* undefined = jsgraph()->UndefinedConstant(); |
775 AllocationBuilder a(jsgraph(), effect, control); | 775 AllocationBuilder a(jsgraph(), effect, control); |
776 STATIC_ASSERT(JSFunction::kSize == 9 * kPointerSize); | 776 STATIC_ASSERT(JSFunction::kSize == 9 * kPointerSize); |
777 a.Allocate(JSFunction::kSize, p.pretenure()); | 777 a.Allocate(JSFunction::kSize, p.pretenure()); |
778 a.Store(AccessBuilder::ForMap(), function_map); | 778 a.Store(AccessBuilder::ForMap(), function_map); |
779 a.Store(AccessBuilder::ForJSObjectProperties(), empty_fixed_array); | 779 a.Store(AccessBuilder::ForJSObjectProperties(), empty_fixed_array); |
780 a.Store(AccessBuilder::ForJSObjectElements(), empty_fixed_array); | 780 a.Store(AccessBuilder::ForJSObjectElements(), empty_fixed_array); |
781 a.Store(AccessBuilder::ForJSFunctionLiterals(), empty_literals_array); | 781 a.Store(AccessBuilder::ForJSFunctionFeedbackVector(), empty_feedback_vector); |
782 a.Store(AccessBuilder::ForJSFunctionPrototypeOrInitialMap(), the_hole); | 782 a.Store(AccessBuilder::ForJSFunctionPrototypeOrInitialMap(), the_hole); |
783 a.Store(AccessBuilder::ForJSFunctionSharedFunctionInfo(), shared); | 783 a.Store(AccessBuilder::ForJSFunctionSharedFunctionInfo(), shared); |
784 a.Store(AccessBuilder::ForJSFunctionContext(), context); | 784 a.Store(AccessBuilder::ForJSFunctionContext(), context); |
785 a.Store(AccessBuilder::ForJSFunctionCodeEntry(), compile_entry); | 785 a.Store(AccessBuilder::ForJSFunctionCodeEntry(), compile_entry); |
786 a.Store(AccessBuilder::ForJSFunctionNextFunctionLink(), undefined); | 786 a.Store(AccessBuilder::ForJSFunctionNextFunctionLink(), undefined); |
787 RelaxControls(node); | 787 RelaxControls(node); |
788 a.FinishAndChange(node); | 788 a.FinishAndChange(node); |
789 return Changed(node); | 789 return Changed(node); |
790 } | 790 } |
791 | 791 |
(...skipping 51 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
843 return Changed(node); | 843 return Changed(node); |
844 } | 844 } |
845 | 845 |
846 Reduction JSCreateLowering::ReduceJSCreateLiteral(Node* node) { | 846 Reduction JSCreateLowering::ReduceJSCreateLiteral(Node* node) { |
847 DCHECK(node->opcode() == IrOpcode::kJSCreateLiteralArray || | 847 DCHECK(node->opcode() == IrOpcode::kJSCreateLiteralArray || |
848 node->opcode() == IrOpcode::kJSCreateLiteralObject); | 848 node->opcode() == IrOpcode::kJSCreateLiteralObject); |
849 CreateLiteralParameters const& p = CreateLiteralParametersOf(node->op()); | 849 CreateLiteralParameters const& p = CreateLiteralParametersOf(node->op()); |
850 Node* effect = NodeProperties::GetEffectInput(node); | 850 Node* effect = NodeProperties::GetEffectInput(node); |
851 Node* control = NodeProperties::GetControlInput(node); | 851 Node* control = NodeProperties::GetControlInput(node); |
852 | 852 |
853 Handle<LiteralsArray> literals_array; | 853 Handle<TypeFeedbackVector> feedback_vector; |
854 if (GetSpecializationLiterals(node).ToHandle(&literals_array)) { | 854 if (GetSpecializationTypeFeedbackVector(node).ToHandle(&feedback_vector)) { |
855 Handle<Object> literal(literals_array->literal(p.index()), isolate()); | 855 FeedbackVectorSlot slot(TypeFeedbackVector::ToSlot(p.index())); |
| 856 Handle<Object> literal(feedback_vector->Get(slot), isolate()); |
856 if (literal->IsAllocationSite()) { | 857 if (literal->IsAllocationSite()) { |
857 Handle<AllocationSite> site = Handle<AllocationSite>::cast(literal); | 858 Handle<AllocationSite> site = Handle<AllocationSite>::cast(literal); |
858 Handle<JSObject> boilerplate(JSObject::cast(site->transition_info()), | 859 Handle<JSObject> boilerplate(JSObject::cast(site->transition_info()), |
859 isolate()); | 860 isolate()); |
860 int max_properties = kMaxFastLiteralProperties; | 861 int max_properties = kMaxFastLiteralProperties; |
861 if (IsFastLiteral(boilerplate, kMaxFastLiteralDepth, &max_properties)) { | 862 if (IsFastLiteral(boilerplate, kMaxFastLiteralDepth, &max_properties)) { |
862 AllocationSiteUsageContext site_context(isolate(), site, false); | 863 AllocationSiteUsageContext site_context(isolate(), site, false); |
863 site_context.EnterNewScope(); | 864 site_context.EnterNewScope(); |
864 Node* value = effect = | 865 Node* value = effect = |
865 AllocateFastLiteral(effect, control, boilerplate, &site_context); | 866 AllocateFastLiteral(effect, control, boilerplate, &site_context); |
(...skipping 470 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1336 ElementAccess const access = | 1337 ElementAccess const access = |
1337 (elements_map->instance_type() == FIXED_DOUBLE_ARRAY_TYPE) | 1338 (elements_map->instance_type() == FIXED_DOUBLE_ARRAY_TYPE) |
1338 ? AccessBuilder::ForFixedDoubleArrayElement() | 1339 ? AccessBuilder::ForFixedDoubleArrayElement() |
1339 : AccessBuilder::ForFixedArrayElement(); | 1340 : AccessBuilder::ForFixedArrayElement(); |
1340 for (int i = 0; i < elements_length; ++i) { | 1341 for (int i = 0; i < elements_length; ++i) { |
1341 builder.Store(access, jsgraph()->Constant(i), elements_values[i]); | 1342 builder.Store(access, jsgraph()->Constant(i), elements_values[i]); |
1342 } | 1343 } |
1343 return builder.Finish(); | 1344 return builder.Finish(); |
1344 } | 1345 } |
1345 | 1346 |
1346 MaybeHandle<LiteralsArray> JSCreateLowering::GetSpecializationLiterals( | 1347 MaybeHandle<TypeFeedbackVector> |
1347 Node* node) { | 1348 JSCreateLowering::GetSpecializationTypeFeedbackVector(Node* node) { |
1348 Node* const closure = NodeProperties::GetValueInput(node, 0); | 1349 Node* const closure = NodeProperties::GetValueInput(node, 0); |
1349 switch (closure->opcode()) { | 1350 switch (closure->opcode()) { |
1350 case IrOpcode::kHeapConstant: { | 1351 case IrOpcode::kHeapConstant: { |
1351 Handle<HeapObject> object = OpParameter<Handle<HeapObject>>(closure); | 1352 Handle<HeapObject> object = OpParameter<Handle<HeapObject>>(closure); |
1352 return handle(Handle<JSFunction>::cast(object)->literals()); | 1353 return handle(Handle<JSFunction>::cast(object)->feedback_vector()); |
1353 } | 1354 } |
1354 case IrOpcode::kParameter: { | 1355 case IrOpcode::kParameter: { |
1355 int const index = ParameterIndexOf(closure->op()); | 1356 int const index = ParameterIndexOf(closure->op()); |
1356 // The closure is always the last parameter to a JavaScript function, and | 1357 // The closure is always the last parameter to a JavaScript function, and |
1357 // {Parameter} indices start at -1, so value outputs of {Start} look like | 1358 // {Parameter} indices start at -1, so value outputs of {Start} look like |
1358 // this: closure, receiver, param0, ..., paramN, context. | 1359 // this: closure, receiver, param0, ..., paramN, context. |
1359 if (index == -1) { | 1360 if (index == -1) { |
1360 return literals_array_; | 1361 return feedback_vector_; |
1361 } | 1362 } |
1362 break; | 1363 break; |
1363 } | 1364 } |
1364 default: | 1365 default: |
1365 break; | 1366 break; |
1366 } | 1367 } |
1367 return MaybeHandle<LiteralsArray>(); | 1368 return MaybeHandle<TypeFeedbackVector>(); |
1368 } | 1369 } |
1369 | 1370 |
1370 Factory* JSCreateLowering::factory() const { return isolate()->factory(); } | 1371 Factory* JSCreateLowering::factory() const { return isolate()->factory(); } |
1371 | 1372 |
1372 Graph* JSCreateLowering::graph() const { return jsgraph()->graph(); } | 1373 Graph* JSCreateLowering::graph() const { return jsgraph()->graph(); } |
1373 | 1374 |
1374 Isolate* JSCreateLowering::isolate() const { return jsgraph()->isolate(); } | 1375 Isolate* JSCreateLowering::isolate() const { return jsgraph()->isolate(); } |
1375 | 1376 |
1376 JSOperatorBuilder* JSCreateLowering::javascript() const { | 1377 JSOperatorBuilder* JSCreateLowering::javascript() const { |
1377 return jsgraph()->javascript(); | 1378 return jsgraph()->javascript(); |
1378 } | 1379 } |
1379 | 1380 |
1380 CommonOperatorBuilder* JSCreateLowering::common() const { | 1381 CommonOperatorBuilder* JSCreateLowering::common() const { |
1381 return jsgraph()->common(); | 1382 return jsgraph()->common(); |
1382 } | 1383 } |
1383 | 1384 |
1384 SimplifiedOperatorBuilder* JSCreateLowering::simplified() const { | 1385 SimplifiedOperatorBuilder* JSCreateLowering::simplified() const { |
1385 return jsgraph()->simplified(); | 1386 return jsgraph()->simplified(); |
1386 } | 1387 } |
1387 | 1388 |
1388 MachineOperatorBuilder* JSCreateLowering::machine() const { | 1389 MachineOperatorBuilder* JSCreateLowering::machine() const { |
1389 return jsgraph()->machine(); | 1390 return jsgraph()->machine(); |
1390 } | 1391 } |
1391 | 1392 |
1392 } // namespace compiler | 1393 } // namespace compiler |
1393 } // namespace internal | 1394 } // namespace internal |
1394 } // namespace v8 | 1395 } // namespace v8 |
OLD | NEW |