6 #include "src/builtins/builtins-utils-gen.h" 7 #include "src/builtins/builtins.h" 8 #include "src/code-stub-assembler.h" 9 #include "src/heap/heap-inl.h" 10 #include "src/ic/accessor-assembler.h" 11 #include "src/ic/keyed-store-generic.h" 12 #include "src/macro-assembler.h" 13 #include "src/objects/debug-objects.h" 14 #include "src/objects/shared-function-info.h" 15 #include "src/runtime/runtime.h" 21 using TNode = compiler::TNode<T>;
26 void Builtins::Generate_InterruptCheck(MacroAssembler* masm) {
27 masm->TailCallRuntime(Runtime::kInterrupt);
30 void Builtins::Generate_StackCheck(MacroAssembler* masm) {
31 masm->TailCallRuntime(Runtime::kStackGuard);
37 TF_BUILTIN(CopyFastSmiOrObjectElements, CodeStubAssembler) {
38 Node*
object = Parameter(Descriptor::kObject);
41 Node* source = LoadObjectField(
object, JSObject::kElementsOffset);
42 Node* target = CloneFixedArray(source, ExtractFixedArrayFlag::kFixedArrays);
43 StoreObjectField(
object, JSObject::kElementsOffset, target);
47 TF_BUILTIN(GrowFastDoubleElements, CodeStubAssembler) {
48 Node*
object = Parameter(Descriptor::kObject);
49 Node* key = Parameter(Descriptor::kKey);
50 Node* context = Parameter(Descriptor::kContext);
52 Label runtime(
this, Label::kDeferred);
53 Node* elements = LoadElements(
object);
54 elements = TryGrowElementsCapacity(
object, elements, PACKED_DOUBLE_ELEMENTS,
59 TailCallRuntime(Runtime::kGrowArrayElements, context,
object, key);
62 TF_BUILTIN(GrowFastSmiOrObjectElements, CodeStubAssembler) {
63 Node*
object = Parameter(Descriptor::kObject);
64 Node* key = Parameter(Descriptor::kKey);
65 Node* context = Parameter(Descriptor::kContext);
67 Label runtime(
this, Label::kDeferred);
68 Node* elements = LoadElements(
object);
70 TryGrowElementsCapacity(
object, elements, PACKED_ELEMENTS, key, &runtime);
74 TailCallRuntime(Runtime::kGrowArrayElements, context,
object, key);
77 TF_BUILTIN(NewArgumentsElements, CodeStubAssembler) {
78 Node* frame = Parameter(Descriptor::kFrame);
79 TNode<IntPtrT> length = SmiToIntPtr(Parameter(Descriptor::kLength));
80 TNode<IntPtrT> mapped_count =
81 SmiToIntPtr(Parameter(Descriptor::kMappedCount));
84 ElementsKind kind = PACKED_ELEMENTS;
85 int max_elements = FixedArray::GetMaxLengthForNewSpaceAllocation(kind);
86 Label if_newspace(
this), if_oldspace(
this, Label::kDeferred);
87 Branch(IntPtrLessThan(length, IntPtrConstant(max_elements)), &if_newspace,
94 Label if_empty(
this), if_notempty(
this);
95 Branch(IntPtrLessThanOrEqual(length, IntPtrConstant(0)), &if_empty,
99 Return(EmptyFixedArrayConstant());
104 TNode<FixedArray> result = CAST(AllocateFixedArray(kind, length));
109 TNode<IntPtrT> number_of_holes = IntPtrMin(mapped_count, length);
110 Node* the_hole = TheHoleConstant();
113 TVARIABLE(IntPtrT, var_index, IntPtrConstant(0));
114 Label loop1(
this, &var_index), done_loop1(
this);
119 TNode<IntPtrT> index = var_index.value();
122 GotoIf(WordEqual(index, number_of_holes), &done_loop1);
125 StoreFixedArrayElement(result, index, the_hole, SKIP_WRITE_BARRIER);
128 var_index = IntPtrAdd(index, IntPtrConstant(1));
134 TNode<IntPtrT> offset = IntPtrAdd(length, IntPtrConstant(1));
137 Label loop2(
this, &var_index), done_loop2(
this);
142 TNode<IntPtrT> index = var_index.value();
145 GotoIf(WordEqual(index, length), &done_loop2);
148 TNode<Object> value =
149 CAST(Load(MachineType::AnyTagged(), frame,
150 TimesPointerSize(IntPtrSub(offset, index))));
153 StoreFixedArrayElement(result, index, value, SKIP_WRITE_BARRIER);
156 var_index = IntPtrAdd(index, IntPtrConstant(1));
168 TailCallRuntime(Runtime::kNewArgumentsElements, NoContextConstant(),
169 BitcastWordToTagged(frame), SmiFromIntPtr(length),
170 SmiFromIntPtr(mapped_count));
174 TF_BUILTIN(ReturnReceiver, CodeStubAssembler) {
175 Return(Parameter(Descriptor::kReceiver));
178 TF_BUILTIN(DebugBreakTrampoline, CodeStubAssembler) {
179 Label tailcall_to_shared(
this);
180 TNode<Context> context = CAST(Parameter(Descriptor::kContext));
181 TNode<Object> new_target = CAST(Parameter(Descriptor::kJSNewTarget));
182 TNode<Int32T> arg_count =
183 UncheckedCast<Int32T>(Parameter(Descriptor::kJSActualArgumentsCount));
184 TNode<JSFunction>
function = CAST(Parameter(Descriptor::kJSTarget));
187 TNode<SharedFunctionInfo> shared =
188 CAST(LoadObjectField(
function, JSFunction::kSharedFunctionInfoOffset));
189 TNode<Object> maybe_heap_object_or_smi =
190 LoadObjectField(shared, SharedFunctionInfo::kScriptOrDebugInfoOffset);
191 TNode<HeapObject> maybe_debug_info =
192 TaggedToHeapObject(maybe_heap_object_or_smi, &tailcall_to_shared);
193 GotoIfNot(HasInstanceType(maybe_debug_info, InstanceType::DEBUG_INFO_TYPE),
194 &tailcall_to_shared);
197 TNode<DebugInfo> debug_info = CAST(maybe_debug_info);
199 CAST(LoadObjectField(debug_info, DebugInfo::kFlagsOffset));
200 GotoIfNot(SmiToInt32(SmiAnd(flags, SmiConstant(DebugInfo::kBreakAtEntry))),
201 &tailcall_to_shared);
203 CallRuntime(Runtime::kDebugBreakAtEntry, context,
function);
204 Goto(&tailcall_to_shared);
207 BIND(&tailcall_to_shared);
209 TNode<Code> code = GetSharedFunctionInfoCode(shared);
210 TailCallJSCode(code, context,
function, new_target, arg_count);
219 Node* is_marking_addr = ExternalConstant(
220 ExternalReference::heap_is_marking_flag_address(this->isolate()));
221 return Load(MachineType::Uint8(), is_marking_addr);
224 Node* IsPageFlagSet(
Node*
object,
int mask) {
225 Node* page = WordAnd(
object, IntPtrConstant(~kPageAlignmentMask));
226 Node* flags = Load(MachineType::Pointer(), page,
227 IntPtrConstant(MemoryChunk::kFlagsOffset));
228 return WordNotEqual(WordAnd(flags, IntPtrConstant(mask)),
233 DCHECK_EQ(strcmp(Marking::kWhiteBitPattern,
"00"), 0);
236 GetMarkBit(
object, &cell, &mask);
237 mask = TruncateIntPtrToInt32(mask);
240 return Word32Equal(Word32And(Load(MachineType::Int32(), cell), mask),
244 void GetMarkBit(
Node*
object,
Node** cell,
Node** mask) {
245 Node* page = WordAnd(
object, IntPtrConstant(~kPageAlignmentMask));
246 Node* bitmap = Load(MachineType::Pointer(), page,
247 IntPtrConstant(MemoryChunk::kMarkBitmapOffset));
252 int shift = Bitmap::kBitsPerCellLog2 + kPointerSizeLog2 -
253 Bitmap::kBytesPerCellLog2;
254 r0 = WordShr(
object, IntPtrConstant(shift));
255 r0 = WordAnd(r0, IntPtrConstant((kPageAlignmentMask >> shift) &
256 ~(Bitmap::kBytesPerCell - 1)));
257 *cell = IntPtrAdd(bitmap, r0);
262 r1 = WordShr(
object, IntPtrConstant(kPointerSizeLog2));
263 r1 = WordAnd(r1, IntPtrConstant((1 << Bitmap::kBitsPerCellLog2) - 1));
267 *mask = WordShl(IntPtrConstant(1), r1);
271 Node* ShouldSkipFPRegs(
Node* mode) {
272 return WordEqual(mode, SmiConstant(kDontSaveFPRegs));
275 Node* ShouldEmitRememberSet(
Node* remembered_set) {
276 return WordEqual(remembered_set, SmiConstant(EMIT_REMEMBERED_SET));
279 void CallCFunction1WithCallerSavedRegistersMode(
MachineType return_type,
283 Label dont_save_fp(
this), save_fp(
this);
284 Branch(ShouldSkipFPRegs(mode), &dont_save_fp, &save_fp);
287 CallCFunction1WithCallerSavedRegisters(return_type, arg0_type,
function,
288 arg0, kDontSaveFPRegs);
294 CallCFunction1WithCallerSavedRegisters(return_type, arg0_type,
function,
300 void CallCFunction3WithCallerSavedRegistersMode(
304 Label dont_save_fp(
this), save_fp(
this);
305 Branch(ShouldSkipFPRegs(mode), &dont_save_fp, &save_fp);
308 CallCFunction3WithCallerSavedRegisters(return_type, arg0_type, arg1_type,
309 arg2_type,
function, arg0, arg1,
310 arg2, kDontSaveFPRegs);
316 CallCFunction3WithCallerSavedRegisters(return_type, arg0_type, arg1_type,
317 arg2_type,
function, arg0, arg1,
323 void InsertToStoreBufferAndGoto(
Node* isolate,
Node* slot,
Node* mode,
325 Node* store_buffer_top_addr =
326 ExternalConstant(ExternalReference::store_buffer_top(this->isolate()));
327 Node* store_buffer_top =
328 Load(MachineType::Pointer(), store_buffer_top_addr);
329 StoreNoWriteBarrier(MachineType::PointerRepresentation(), store_buffer_top,
331 Node* new_store_buffer_top =
332 IntPtrAdd(store_buffer_top, IntPtrConstant(kPointerSize));
333 StoreNoWriteBarrier(MachineType::PointerRepresentation(),
334 store_buffer_top_addr, new_store_buffer_top);
336 Node* test = WordAnd(new_store_buffer_top,
337 IntPtrConstant(Heap::store_buffer_mask_constant()));
339 Label overflow(
this);
340 Branch(WordEqual(test, IntPtrConstant(0)), &overflow, next);
345 ExternalConstant(ExternalReference::store_buffer_overflow_function());
346 CallCFunction1WithCallerSavedRegistersMode(MachineType::Int32(),
347 MachineType::Pointer(),
348 function, isolate, mode, next);
354 Label generational_wb(
this);
355 Label incremental_wb(
this);
358 Node* remembered_set = Parameter(Descriptor::kRememberedSet);
359 Branch(ShouldEmitRememberSet(remembered_set), &generational_wb,
362 BIND(&generational_wb);
364 Label test_old_to_new_flags(
this);
365 Label store_buffer_exit(
this), store_buffer_incremental_wb(
this);
373 Node* slot = Parameter(Descriptor::kSlot);
374 Branch(IsMarking(), &test_old_to_new_flags, &store_buffer_exit);
376 BIND(&test_old_to_new_flags);
378 Node* value = Load(MachineType::Pointer(), slot);
382 Node* value_in_new_space =
383 IsPageFlagSet(value, MemoryChunk::kIsInNewSpaceMask);
384 GotoIfNot(value_in_new_space, &incremental_wb);
386 Node*
object = BitcastTaggedToWord(Parameter(Descriptor::kObject));
387 Node* object_in_new_space =
388 IsPageFlagSet(
object, MemoryChunk::kIsInNewSpaceMask);
389 Branch(object_in_new_space, &incremental_wb,
390 &store_buffer_incremental_wb);
393 BIND(&store_buffer_exit);
395 Node* isolate_constant =
396 ExternalConstant(ExternalReference::isolate_address(isolate()));
397 Node* fp_mode = Parameter(Descriptor::kFPMode);
398 InsertToStoreBufferAndGoto(isolate_constant, slot, fp_mode, &exit);
401 BIND(&store_buffer_incremental_wb);
403 Node* isolate_constant =
404 ExternalConstant(ExternalReference::isolate_address(isolate()));
405 Node* fp_mode = Parameter(Descriptor::kFPMode);
406 InsertToStoreBufferAndGoto(isolate_constant, slot, fp_mode,
411 BIND(&incremental_wb);
413 Label call_incremental_wb(
this);
415 Node* slot = Parameter(Descriptor::kSlot);
416 Node* value = Load(MachineType::Pointer(), slot);
420 GotoIf(IsWhite(value), &call_incremental_wb);
424 GotoIfNot(IsPageFlagSet(value, MemoryChunk::kEvacuationCandidateMask),
427 Node*
object = BitcastTaggedToWord(Parameter(Descriptor::kObject));
429 IsPageFlagSet(
object, MemoryChunk::kSkipEvacuationSlotsRecordingMask),
430 &exit, &call_incremental_wb);
432 BIND(&call_incremental_wb);
434 Node*
function = ExternalConstant(
435 ExternalReference::incremental_marking_record_write_function());
436 Node* isolate_constant =
437 ExternalConstant(ExternalReference::isolate_address(isolate()));
438 Node* fp_mode = Parameter(Descriptor::kFPMode);
439 Node*
object = BitcastTaggedToWord(Parameter(Descriptor::kObject));
440 CallCFunction3WithCallerSavedRegistersMode(
441 MachineType::Int32(), MachineType::Pointer(), MachineType::Pointer(),
442 MachineType::Pointer(),
function,
object, slot, isolate_constant,
448 Return(TrueConstant());
460 TVARIABLE(
IntPtrT, var_name_index);
461 Label dictionary_found(
this, &var_name_index);
462 NameDictionaryLookup<NameDictionary>(properties, name, &dictionary_found,
463 &var_name_index, notfound);
465 BIND(&dictionary_found);
468 LoadDetailsByKeyIndex<NameDictionary>(properties, key_index);
469 GotoIf(IsSetWord32(details, PropertyDetails::kAttributesDontDeleteMask),
473 DCHECK(RootsTable::IsImmortalImmovable(RootIndex::kTheHoleValue));
474 StoreFixedArrayElement(properties, key_index, filler, SKIP_WRITE_BARRIER);
475 StoreValueByKeyIndex<NameDictionary>(properties, key_index, filler,
477 StoreDetailsByKeyIndex<NameDictionary>(properties, key_index,
481 TNode<Smi> nof = GetNumberOfElements<NameDictionary>(properties);
482 TNode<Smi> new_nof = SmiSub(nof, SmiConstant(1));
483 SetNumberOfElements<NameDictionary>(properties, new_nof);
485 GetNumberOfDeletedElements<NameDictionary>(properties);
486 TNode<Smi> new_deleted = SmiAdd(num_deleted, SmiConstant(1));
487 SetNumberOfDeletedElements<NameDictionary>(properties, new_deleted);
490 Label shrinking_done(
this);
491 TNode<Smi> capacity = GetCapacity<NameDictionary>(properties);
492 GotoIf(SmiGreaterThan(new_nof, SmiShr(capacity, 2)), &shrinking_done);
493 GotoIf(SmiLessThan(new_nof, SmiConstant(16)), &shrinking_done);
494 CallRuntime(Runtime::kShrinkPropertyDictionary, context, receiver);
495 Goto(&shrinking_done);
496 BIND(&shrinking_done);
498 Return(TrueConstant());
503 TNode<Object> receiver = CAST(Parameter(Descriptor::kObject));
505 TNode<Smi> language_mode = CAST(Parameter(Descriptor::kLanguageMode));
508 VARIABLE(var_index, MachineType::PointerRepresentation());
509 VARIABLE(var_unique, MachineRepresentation::kTagged, key);
510 Label if_index(
this), if_unique_name(
this), if_notunique(
this),
511 if_notfound(
this), slow(
this);
513 GotoIf(TaggedIsSmi(receiver), &slow);
514 TNode<Map> receiver_map = LoadMap(CAST(receiver));
515 TNode<Int32T> instance_type = LoadMapInstanceType(receiver_map);
516 GotoIf(IsCustomElementsReceiverInstanceType(instance_type), &slow);
517 TryToName(key, &if_index, &var_index, &if_unique_name, &var_unique, &slow,
522 Comment(
"integer index");
526 BIND(&if_unique_name);
528 Comment(
"key is unique name");
529 TNode<Name> unique = CAST(var_unique.value());
530 CheckForAssociatedProtector(unique, &slow);
532 Label dictionary(
this), dont_delete(
this);
533 GotoIf(IsDictionaryMap(receiver_map), &dictionary);
541 InvalidateValidityCellIfPrototype(receiver_map);
543 TNode<NameDictionary> properties =
544 CAST(LoadSlowProperties(CAST(receiver)));
545 DeleteDictionaryProperty(receiver, properties, unique, context,
546 &dont_delete, &if_notfound);
551 STATIC_ASSERT(LanguageModeSize == 2);
552 GotoIf(SmiNotEqual(language_mode, SmiConstant(LanguageMode::kSloppy)),
554 Return(FalseConstant());
562 TryInternalizeString(key, &if_index, &var_index, &if_unique_name,
563 &var_unique, &if_notfound, &slow);
567 Return(TrueConstant());
571 TailCallRuntime(Runtime::kDeleteProperty, context, receiver, key,
576 TF_BUILTIN(ForInEnumerate, CodeStubAssembler) {
577 Node* receiver = Parameter(Descriptor::kReceiver);
578 Node* context = Parameter(Descriptor::kContext);
580 Label if_empty(
this), if_runtime(
this, Label::kDeferred);
581 Node* receiver_map = CheckEnumCache(receiver, &if_empty, &if_runtime);
582 Return(receiver_map);
585 Return(EmptyFixedArrayConstant());
588 TailCallRuntime(Runtime::kForInEnumerate, context, receiver);
591 TF_BUILTIN(ForInFilter, CodeStubAssembler) {
592 Node* key = Parameter(Descriptor::kKey);
593 Node*
object = Parameter(Descriptor::kObject);
594 Node* context = Parameter(Descriptor::kContext);
596 CSA_ASSERT(
this, IsString(key));
598 Label if_true(
this), if_false(
this);
599 TNode<Oddball> result = HasProperty(context,
object, key, kForInHasProperty);
600 Branch(IsTrue(result), &if_true, &if_false);
606 Return(UndefinedConstant());
609 TF_BUILTIN(SameValue, CodeStubAssembler) {
610 Node* lhs = Parameter(Descriptor::kLeft);
611 Node* rhs = Parameter(Descriptor::kRight);
613 Label if_true(
this), if_false(
this);
614 BranchIfSameValue(lhs, rhs, &if_true, &if_false);
617 Return(TrueConstant());
620 Return(FalseConstant());
628 template <
typename Descriptor>
629 void GenerateAdaptorWithExitFrameType(
630 Builtins::ExitFrameType exit_frame_type);
633 template <
typename Descriptor>
634 void InternalBuiltinsAssembler::GenerateAdaptorWithExitFrameType(
635 Builtins::ExitFrameType exit_frame_type) {
637 TNode<Object> new_target = CAST(Parameter(Descriptor::kNewTarget));
639 UncheckedCast<WordT>(Parameter(Descriptor::kCFunction));
649 CAST(LoadObjectField(target, JSFunction::kContextOffset));
654 UncheckedCast<Int32T>(Parameter(Descriptor::kActualArgumentsCount));
657 Int32Constant(BuiltinExitFrameConstants::kNumExtraArgsWithReceiver));
660 CodeFactory::CEntry(isolate(), 1, kDontSaveFPRegs, kArgvOnStack,
661 exit_frame_type == Builtins::BUILTIN_EXIT));
674 TF_BUILTIN(AdaptorWithExitFrame, InternalBuiltinsAssembler) {
675 GenerateAdaptorWithExitFrameType<Descriptor>(Builtins::EXIT);
678 TF_BUILTIN(AdaptorWithBuiltinExitFrame, InternalBuiltinsAssembler) {
679 GenerateAdaptorWithExitFrameType<Descriptor>(Builtins::BUILTIN_EXIT);
682 TF_BUILTIN(AllocateInNewSpace, CodeStubAssembler) {
683 TNode<IntPtrT> requested_size =
684 UncheckedCast<IntPtrT>(Parameter(Descriptor::kRequestedSize));
686 TailCallRuntime(Runtime::kAllocateInNewSpace, NoContextConstant(),
687 SmiFromIntPtr(requested_size));
690 TF_BUILTIN(AllocateInOldSpace, CodeStubAssembler) {
691 TNode<IntPtrT> requested_size =
692 UncheckedCast<IntPtrT>(Parameter(Descriptor::kRequestedSize));
694 int flags = AllocateTargetSpace::encode(OLD_SPACE);
695 TailCallRuntime(Runtime::kAllocateInTargetSpace, NoContextConstant(),
696 SmiFromIntPtr(requested_size), SmiConstant(flags));
699 TF_BUILTIN(Abort, CodeStubAssembler) {
700 TNode<Smi> message_id = CAST(Parameter(Descriptor::kMessageOrMessageId));
701 TailCallRuntime(Runtime::kAbort, NoContextConstant(), message_id);
704 TF_BUILTIN(AbortJS, CodeStubAssembler) {
705 TNode<String> message = CAST(Parameter(Descriptor::kMessageOrMessageId));
706 TailCallRuntime(Runtime::kAbortJS, NoContextConstant(), message);
709 void Builtins::Generate_CEntry_Return1_DontSaveFPRegs_ArgvOnStack_NoBuiltinExit(
710 MacroAssembler* masm) {
711 Generate_CEntry(masm, 1, kDontSaveFPRegs, kArgvOnStack,
false);
714 void Builtins::Generate_CEntry_Return1_DontSaveFPRegs_ArgvOnStack_BuiltinExit(
715 MacroAssembler* masm) {
716 Generate_CEntry(masm, 1, kDontSaveFPRegs, kArgvOnStack,
true);
720 Generate_CEntry_Return1_DontSaveFPRegs_ArgvInRegister_NoBuiltinExit(
721 MacroAssembler* masm) {
722 Generate_CEntry(masm, 1, kDontSaveFPRegs, kArgvInRegister,
false);
725 void Builtins::Generate_CEntry_Return1_SaveFPRegs_ArgvOnStack_NoBuiltinExit(
726 MacroAssembler* masm) {
727 Generate_CEntry(masm, 1, kSaveFPRegs, kArgvOnStack,
false);
730 void Builtins::Generate_CEntry_Return1_SaveFPRegs_ArgvOnStack_BuiltinExit(
731 MacroAssembler* masm) {
732 Generate_CEntry(masm, 1, kSaveFPRegs, kArgvOnStack,
true);
735 void Builtins::Generate_CEntry_Return2_DontSaveFPRegs_ArgvOnStack_NoBuiltinExit(
736 MacroAssembler* masm) {
737 Generate_CEntry(masm, 2, kDontSaveFPRegs, kArgvOnStack,
false);
740 void Builtins::Generate_CEntry_Return2_DontSaveFPRegs_ArgvOnStack_BuiltinExit(
741 MacroAssembler* masm) {
742 Generate_CEntry(masm, 2, kDontSaveFPRegs, kArgvOnStack,
true);
746 Generate_CEntry_Return2_DontSaveFPRegs_ArgvInRegister_NoBuiltinExit(
747 MacroAssembler* masm) {
748 Generate_CEntry(masm, 2, kDontSaveFPRegs, kArgvInRegister,
false);
751 void Builtins::Generate_CEntry_Return2_SaveFPRegs_ArgvOnStack_NoBuiltinExit(
752 MacroAssembler* masm) {
753 Generate_CEntry(masm, 2, kSaveFPRegs, kArgvOnStack,
false);
756 void Builtins::Generate_CEntry_Return2_SaveFPRegs_ArgvOnStack_BuiltinExit(
757 MacroAssembler* masm) {
758 Generate_CEntry(masm, 2, kSaveFPRegs, kArgvOnStack,
true);
761 void Builtins::Generate_CallApiGetter(MacroAssembler* masm) {
765 CallApiGetterStub stub(masm->isolate());
769 void Builtins::Generate_CallApiCallback_Argc0(MacroAssembler* masm) {
775 CallApiCallbackStub stub(masm->isolate(), kArgc);
779 void Builtins::Generate_CallApiCallback_Argc1(MacroAssembler* masm) {
785 CallApiCallbackStub stub(masm->isolate(), kArgc);
790 TF_BUILTIN(GetProperty, CodeStubAssembler) {
791 Node*
object = Parameter(Descriptor::kObject);
792 Node* key = Parameter(Descriptor::kKey);
793 Node* context = Parameter(Descriptor::kContext);
794 Label if_notfound(
this), if_proxy(
this, Label::kDeferred),
795 if_slow(
this, Label::kDeferred);
797 CodeStubAssembler::LookupInHolder lookup_property_in_holder =
798 [=](Node* receiver, Node* holder, Node* holder_map,
799 Node* holder_instance_type, Node* unique_name, Label* next_holder,
801 VARIABLE(var_value, MachineRepresentation::kTagged);
802 Label if_found(
this);
803 TryGetOwnProperty(context, receiver, holder, holder_map,
804 holder_instance_type, unique_name, &if_found,
805 &var_value, next_holder, if_bailout);
807 Return(var_value.value());
810 CodeStubAssembler::LookupInHolder lookup_element_in_holder =
811 [=](Node* receiver, Node* holder, Node* holder_map,
812 Node* holder_instance_type, Node* index, Label* next_holder,
819 TryPrototypeChainLookup(
object, key, lookup_property_in_holder,
820 lookup_element_in_holder, &if_notfound, &if_slow,
824 Return(UndefinedConstant());
827 TailCallRuntime(Runtime::kGetProperty, context,
object, key);
832 Node* name = CallBuiltin(Builtins::kToName, context, key);
837 TailCallBuiltin(Builtins::kProxyGetProperty, context,
object, name,
object,
838 SmiConstant(OnNonExistent::kReturnUndefined));
843 TF_BUILTIN(SetProperty, CodeStubAssembler) {
844 TNode<Context> context = CAST(Parameter(Descriptor::kContext));
845 TNode<Object> receiver = CAST(Parameter(Descriptor::kReceiver));
846 TNode<Object> key = CAST(Parameter(Descriptor::kKey));
847 TNode<Object> value = CAST(Parameter(Descriptor::kValue));
849 KeyedStoreGenericGenerator::SetProperty(state(), context, receiver, key,
850 value, LanguageMode::kStrict);
857 TF_BUILTIN(SetPropertyInLiteral, CodeStubAssembler) {
858 TNode<Context> context = CAST(Parameter(Descriptor::kContext));
859 TNode<JSObject> receiver = CAST(Parameter(Descriptor::kReceiver));
860 TNode<Object> key = CAST(Parameter(Descriptor::kKey));
861 TNode<Object> value = CAST(Parameter(Descriptor::kValue));
863 KeyedStoreGenericGenerator::SetPropertyInLiteral(state(), context, receiver,