| 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/builtins/builtins-constructor.h" | 5 #include "src/builtins/builtins-constructor.h" |
| 6 #include "src/ast/ast.h" | 6 #include "src/ast/ast.h" |
| 7 #include "src/builtins/builtins-utils.h" | 7 #include "src/builtins/builtins-utils.h" |
| 8 #include "src/builtins/builtins.h" | 8 #include "src/builtins/builtins.h" |
| 9 #include "src/code-factory.h" | 9 #include "src/code-factory.h" |
| 10 #include "src/code-stub-assembler.h" | 10 #include "src/code-stub-assembler.h" |
| (...skipping 102 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 113 | 113 |
| 114 // Get the function map in the current native context and set that | 114 // Get the function map in the current native context and set that |
| 115 // as the map of the allocated object. | 115 // as the map of the allocated object. |
| 116 Node* native_context = LoadNativeContext(context); | 116 Node* native_context = LoadNativeContext(context); |
| 117 Node* map_slot_value = | 117 Node* map_slot_value = |
| 118 LoadFixedArrayElement(native_context, map_index.value()); | 118 LoadFixedArrayElement(native_context, map_index.value()); |
| 119 StoreMapNoWriteBarrier(result, map_slot_value); | 119 StoreMapNoWriteBarrier(result, map_slot_value); |
| 120 | 120 |
| 121 // Initialize the rest of the function. | 121 // Initialize the rest of the function. |
| 122 Node* empty_fixed_array = HeapConstant(factory->empty_fixed_array()); | 122 Node* empty_fixed_array = HeapConstant(factory->empty_fixed_array()); |
| 123 Node* empty_feedback_vector = | |
| 124 HeapConstant(factory->empty_type_feedback_vector()); | |
| 125 StoreObjectFieldNoWriteBarrier(result, JSObject::kPropertiesOffset, | 123 StoreObjectFieldNoWriteBarrier(result, JSObject::kPropertiesOffset, |
| 126 empty_fixed_array); | 124 empty_fixed_array); |
| 127 StoreObjectFieldNoWriteBarrier(result, JSObject::kElementsOffset, | 125 StoreObjectFieldNoWriteBarrier(result, JSObject::kElementsOffset, |
| 128 empty_fixed_array); | 126 empty_fixed_array); |
| 127 Node* literals_cell = LoadFixedArrayElement( |
| 128 feedback_vector, slot, 0, CodeStubAssembler::SMI_PARAMETERS); |
| 129 StoreObjectFieldNoWriteBarrier(result, JSFunction::kFeedbackVectorOffset, | 129 StoreObjectFieldNoWriteBarrier(result, JSFunction::kFeedbackVectorOffset, |
| 130 empty_feedback_vector); | 130 literals_cell); |
| 131 StoreObjectFieldNoWriteBarrier( | 131 StoreObjectFieldNoWriteBarrier( |
| 132 result, JSFunction::kPrototypeOrInitialMapOffset, TheHoleConstant()); | 132 result, JSFunction::kPrototypeOrInitialMapOffset, TheHoleConstant()); |
| 133 StoreObjectFieldNoWriteBarrier(result, JSFunction::kSharedFunctionInfoOffset, | 133 StoreObjectFieldNoWriteBarrier(result, JSFunction::kSharedFunctionInfoOffset, |
| 134 shared_info); | 134 shared_info); |
| 135 StoreObjectFieldNoWriteBarrier(result, JSFunction::kContextOffset, context); | 135 StoreObjectFieldNoWriteBarrier(result, JSFunction::kContextOffset, context); |
| 136 Handle<Code> lazy_builtin_handle( | 136 Handle<Code> lazy_builtin_handle( |
| 137 isolate->builtins()->builtin(Builtins::kCompileLazy)); | 137 isolate->builtins()->builtin(Builtins::kCompileLazy)); |
| 138 Node* lazy_builtin = HeapConstant(lazy_builtin_handle); | 138 Node* lazy_builtin = HeapConstant(lazy_builtin_handle); |
| 139 Node* lazy_builtin_entry = | 139 Node* lazy_builtin_entry = |
| 140 IntPtrAdd(BitcastTaggedToWord(lazy_builtin), | 140 IntPtrAdd(BitcastTaggedToWord(lazy_builtin), |
| (...skipping 253 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 394 Node* flags, | 394 Node* flags, |
| 395 Node* context) { | 395 Node* context) { |
| 396 typedef CodeStubAssembler::Label Label; | 396 typedef CodeStubAssembler::Label Label; |
| 397 typedef CodeStubAssembler::Variable Variable; | 397 typedef CodeStubAssembler::Variable Variable; |
| 398 typedef compiler::Node Node; | 398 typedef compiler::Node Node; |
| 399 | 399 |
| 400 Label call_runtime(this, Label::kDeferred), end(this); | 400 Label call_runtime(this, Label::kDeferred), end(this); |
| 401 | 401 |
| 402 Variable result(this, MachineRepresentation::kTagged); | 402 Variable result(this, MachineRepresentation::kTagged); |
| 403 | 403 |
| 404 Node* vector_array = | 404 Node* cell = LoadObjectField(closure, JSFunction::kFeedbackVectorOffset); |
| 405 LoadObjectField(closure, JSFunction::kFeedbackVectorOffset); | 405 Node* literals_array = LoadObjectField(cell, Cell::kValueOffset); |
| 406 Node* boilerplate = LoadFixedArrayElement(vector_array, literal_index, 0, | 406 Node* boilerplate = LoadFixedArrayElement(literals_array, literal_index, 0, |
| 407 CodeStubAssembler::SMI_PARAMETERS); | 407 CodeStubAssembler::SMI_PARAMETERS); |
| 408 GotoIf(IsUndefined(boilerplate), &call_runtime); | 408 GotoIf(IsUndefined(boilerplate), &call_runtime); |
| 409 | 409 |
| 410 { | 410 { |
| 411 int size = JSRegExp::kSize + JSRegExp::kInObjectFieldCount * kPointerSize; | 411 int size = JSRegExp::kSize + JSRegExp::kInObjectFieldCount * kPointerSize; |
| 412 Node* copy = Allocate(size); | 412 Node* copy = Allocate(size); |
| 413 for (int offset = 0; offset < size; offset += kPointerSize) { | 413 for (int offset = 0; offset < size; offset += kPointerSize) { |
| 414 Node* value = LoadObjectField(boilerplate, offset); | 414 Node* value = LoadObjectField(boilerplate, offset); |
| 415 StoreObjectFieldNoWriteBarrier(copy, offset, value); | 415 StoreObjectFieldNoWriteBarrier(copy, offset, value); |
| 416 } | 416 } |
| (...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 477 Node* closure, Node* literal_index, Node* context, | 477 Node* closure, Node* literal_index, Node* context, |
| 478 CodeAssemblerLabel* call_runtime, AllocationSiteMode allocation_site_mode) { | 478 CodeAssemblerLabel* call_runtime, AllocationSiteMode allocation_site_mode) { |
| 479 typedef CodeStubAssembler::Label Label; | 479 typedef CodeStubAssembler::Label Label; |
| 480 typedef CodeStubAssembler::Variable Variable; | 480 typedef CodeStubAssembler::Variable Variable; |
| 481 typedef compiler::Node Node; | 481 typedef compiler::Node Node; |
| 482 | 482 |
| 483 Label zero_capacity(this), cow_elements(this), fast_elements(this), | 483 Label zero_capacity(this), cow_elements(this), fast_elements(this), |
| 484 return_result(this); | 484 return_result(this); |
| 485 Variable result(this, MachineRepresentation::kTagged); | 485 Variable result(this, MachineRepresentation::kTagged); |
| 486 | 486 |
| 487 Node* vector_array = | 487 Node* cell = LoadObjectField(closure, JSFunction::kFeedbackVectorOffset); |
| 488 LoadObjectField(closure, JSFunction::kFeedbackVectorOffset); | 488 Node* literals_array = LoadObjectField(cell, Cell::kValueOffset); |
| 489 Node* allocation_site = LoadFixedArrayElement( | 489 Node* allocation_site = LoadFixedArrayElement( |
| 490 vector_array, literal_index, 0, CodeStubAssembler::SMI_PARAMETERS); | 490 literals_array, literal_index, 0, CodeStubAssembler::SMI_PARAMETERS); |
| 491 | 491 |
| 492 GotoIf(IsUndefined(allocation_site), call_runtime); | 492 GotoIf(IsUndefined(allocation_site), call_runtime); |
| 493 allocation_site = LoadFixedArrayElement(vector_array, literal_index, 0, | 493 allocation_site = LoadFixedArrayElement(literals_array, literal_index, 0, |
| 494 CodeStubAssembler::SMI_PARAMETERS); | 494 CodeStubAssembler::SMI_PARAMETERS); |
| 495 | 495 |
| 496 Node* boilerplate = | 496 Node* boilerplate = |
| 497 LoadObjectField(allocation_site, AllocationSite::kTransitionInfoOffset); | 497 LoadObjectField(allocation_site, AllocationSite::kTransitionInfoOffset); |
| 498 Node* boilerplate_map = LoadMap(boilerplate); | 498 Node* boilerplate_map = LoadMap(boilerplate); |
| 499 Node* boilerplate_elements = LoadElements(boilerplate); | 499 Node* boilerplate_elements = LoadElements(boilerplate); |
| 500 Node* capacity = LoadFixedArrayBaseLength(boilerplate_elements); | 500 Node* capacity = LoadFixedArrayBaseLength(boilerplate_elements); |
| 501 allocation_site = | 501 allocation_site = |
| 502 allocation_site_mode == TRACK_ALLOCATION_SITE ? allocation_site : nullptr; | 502 allocation_site_mode == TRACK_ALLOCATION_SITE ? allocation_site : nullptr; |
| 503 | 503 |
| (...skipping 131 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 635 // runtime. | 635 // runtime. |
| 636 // TODO(verwaest): Unify this with the heuristic in the runtime. | 636 // TODO(verwaest): Unify this with the heuristic in the runtime. |
| 637 return literal_length == 0 | 637 return literal_length == 0 |
| 638 ? JSObject::kInitialGlobalObjectUnusedPropertiesCount | 638 ? JSObject::kInitialGlobalObjectUnusedPropertiesCount |
| 639 : literal_length; | 639 : literal_length; |
| 640 } | 640 } |
| 641 | 641 |
| 642 Node* ConstructorBuiltinsAssembler::EmitFastCloneShallowObject( | 642 Node* ConstructorBuiltinsAssembler::EmitFastCloneShallowObject( |
| 643 CodeAssemblerLabel* call_runtime, Node* closure, Node* literals_index, | 643 CodeAssemblerLabel* call_runtime, Node* closure, Node* literals_index, |
| 644 Node* properties_count) { | 644 Node* properties_count) { |
| 645 Node* vector_array = | 645 Node* cell = LoadObjectField(closure, JSFunction::kFeedbackVectorOffset); |
| 646 LoadObjectField(closure, JSFunction::kFeedbackVectorOffset); | 646 Node* literals_array = LoadObjectField(cell, Cell::kValueOffset); |
| 647 Node* allocation_site = LoadFixedArrayElement( | 647 Node* allocation_site = LoadFixedArrayElement( |
| 648 vector_array, literals_index, 0, CodeStubAssembler::SMI_PARAMETERS); | 648 literals_array, literals_index, 0, CodeStubAssembler::SMI_PARAMETERS); |
| 649 GotoIf(IsUndefined(allocation_site), call_runtime); | 649 GotoIf(IsUndefined(allocation_site), call_runtime); |
| 650 | 650 |
| 651 // Calculate the object and allocation size based on the properties count. | 651 // Calculate the object and allocation size based on the properties count. |
| 652 Node* object_size = IntPtrAdd(WordShl(properties_count, kPointerSizeLog2), | 652 Node* object_size = IntPtrAdd(WordShl(properties_count, kPointerSizeLog2), |
| 653 IntPtrConstant(JSObject::kHeaderSize)); | 653 IntPtrConstant(JSObject::kHeaderSize)); |
| 654 Node* allocation_size = object_size; | 654 Node* allocation_size = object_size; |
| 655 if (FLAG_allocation_site_pretenuring) { | 655 if (FLAG_allocation_site_pretenuring) { |
| 656 allocation_size = | 656 allocation_size = |
| 657 IntPtrAdd(object_size, IntPtrConstant(AllocationMemento::kSize)); | 657 IntPtrAdd(object_size, IntPtrConstant(AllocationMemento::kSize)); |
| 658 } | 658 } |
| (...skipping 100 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 759 case 6: | 759 case 6: |
| 760 return FastCloneShallowObject6(); | 760 return FastCloneShallowObject6(); |
| 761 default: | 761 default: |
| 762 UNREACHABLE(); | 762 UNREACHABLE(); |
| 763 } | 763 } |
| 764 return Handle<Code>::null(); | 764 return Handle<Code>::null(); |
| 765 } | 765 } |
| 766 | 766 |
| 767 } // namespace internal | 767 } // namespace internal |
| 768 } // namespace v8 | 768 } // namespace v8 |
| OLD | NEW |