Index: src/x64/code-stubs-x64.cc |
diff --git a/src/x64/code-stubs-x64.cc b/src/x64/code-stubs-x64.cc |
index 0637bd2fb928ac1d0f4bea03afab158eedf85d4e..d9ffc455474ad9bec069096e0011387d1c6db4f2 100644 |
--- a/src/x64/code-stubs-x64.cc |
+++ b/src/x64/code-stubs-x64.cc |
@@ -2201,10 +2201,25 @@ static void GenerateRecordCallTarget(MacroAssembler* masm) { |
__ bind(&miss); |
- // A monomorphic miss (i.e, here the cache is not uninitialized) goes |
- // megamorphic. |
+ // A monomorphic miss (i.e, here the cache is not uninitialized or |
+ // pre-monomorphic) goes megamorphic. |
+ Label not_uninitialized; |
__ Cmp(rcx, TypeFeedbackInfo::UninitializedSentinel(isolate)); |
+ __ j(not_equal, ¬_uninitialized); |
+ |
+ // PremonomorphicSentinel is an immortal immovable object (null) so no |
+ // write-barrier is needed. |
+ __ Move(FieldOperand(rbx, rdx, times_pointer_size, FixedArray::kHeaderSize), |
+ TypeFeedbackInfo::PremonomorphicSentinel(isolate)); |
+ __ jmp(&done); |
+ |
+ // If the cache isn't uninitialized, it is either premonomorphic or |
+ // monomorphic. If it is premonomorphic, we initialize it thus making |
+ // it monomorphic. Otherwise, we go megamorphic. |
+ __ bind(¬_uninitialized); |
+ __ Cmp(rcx, TypeFeedbackInfo::PremonomorphicSentinel(isolate)); |
__ j(equal, &initialize); |
+ |
// MegamorphicSentinel is an immortal immovable object (undefined) so no |
// write-barrier is needed. |
__ bind(&megamorphic); |