Index: src/ic/ic.cc |
diff --git a/src/ic/ic.cc b/src/ic/ic.cc |
index 537b18324d6868e29b5a494090f0b4cad59e4e26..25142632e6c54c7aa1a23c592933f723785d0916 100644 |
--- a/src/ic/ic.cc |
+++ b/src/ic/ic.cc |
@@ -982,10 +982,13 @@ Handle<Code> LoadIC::initialize_stub(Isolate* isolate, |
Handle<Code> LoadIC::initialize_stub_in_optimized_code( |
- Isolate* isolate, ExtraICState extra_state) { |
+ Isolate* isolate, ExtraICState extra_state, bool initialize_megamorphic) { |
if (FLAG_vector_ics) { |
return VectorLoadStub(isolate, LoadICState(extra_state)).GetCode(); |
} |
+ if (initialize_megamorphic) { |
+ return PropertyICCompiler::ComputeLoad(isolate, MEGAMORPHIC, extra_state); |
+ } |
return initialize_stub(isolate, extra_state); |
} |
@@ -1606,10 +1609,12 @@ Handle<Code> CallIC::initialize_stub_in_optimized_code( |
Handle<Code> StoreIC::initialize_stub(Isolate* isolate, |
- LanguageMode language_mode) { |
+ LanguageMode language_mode, |
+ bool initialize_megamorphic) { |
ExtraICState extra_state = ComputeExtraICState(language_mode); |
+ InlineCacheState state = initialize_megamorphic ? MEGAMORPHIC : UNINITIALIZED; |
Handle<Code> ic = |
- PropertyICCompiler::ComputeStore(isolate, UNINITIALIZED, extra_state); |
+ PropertyICCompiler::ComputeStore(isolate, state, extra_state); |
return ic; |
} |