| Index: src/ic.h
|
| diff --git a/src/ic.h b/src/ic.h
|
| index 8c448eb7fde7528f0f036dfe7d0197023970dd1f..829c6b1547666c708e41f15c36a7dcc49f4211ee 100644
|
| --- a/src/ic.h
|
| +++ b/src/ic.h
|
| @@ -511,8 +511,8 @@ class StoreIC: public IC {
|
| static void GenerateMegamorphic(MacroAssembler* masm,
|
| StrictModeFlag strict_mode);
|
| static void GenerateNormal(MacroAssembler* masm);
|
| - static void GenerateGlobalProxy(MacroAssembler* masm,
|
| - StrictModeFlag strict_mode);
|
| + static void GenerateRuntimeSetProperty(MacroAssembler* masm,
|
| + StrictModeFlag strict_mode);
|
|
|
| MUST_USE_RESULT MaybeObject* Store(
|
| State state,
|
| @@ -532,6 +532,12 @@ class StoreIC: public IC {
|
| virtual Handle<Code> megamorphic_stub_strict() {
|
| return isolate()->builtins()->StoreIC_Megamorphic_Strict();
|
| }
|
| + virtual Handle<Code> generic_stub() const {
|
| + return isolate()->builtins()->StoreIC_Generic();
|
| + }
|
| + virtual Handle<Code> generic_stub_strict() const {
|
| + return isolate()->builtins()->StoreIC_Generic_Strict();
|
| + }
|
| virtual Handle<Code> global_proxy_stub() {
|
| return isolate()->builtins()->StoreIC_GlobalProxy();
|
| }
|
| @@ -684,6 +690,8 @@ class UnaryOpIC: public IC {
|
| GENERIC
|
| };
|
|
|
| + static Handle<Type> TypeInfoToType(TypeInfo info, Isolate* isolate);
|
| +
|
| explicit UnaryOpIC(Isolate* isolate) : IC(NO_EXTRA_FRAME, isolate) { }
|
|
|
| void patch(Code* code);
|
| @@ -711,6 +719,12 @@ class BinaryOpIC: public IC {
|
| GENERIC
|
| };
|
|
|
| + static void StubInfoToType(int minor_key,
|
| + Handle<Type>* left,
|
| + Handle<Type>* right,
|
| + Handle<Type>* result,
|
| + Isolate* isolate);
|
| +
|
| explicit BinaryOpIC(Isolate* isolate) : IC(NO_EXTRA_FRAME, isolate) { }
|
|
|
| void patch(Code* code);
|
| @@ -718,6 +732,9 @@ class BinaryOpIC: public IC {
|
| static const char* GetName(TypeInfo type_info);
|
|
|
| static State ToState(TypeInfo type_info);
|
| +
|
| + private:
|
| + static Handle<Type> TypeInfoToType(TypeInfo binary_type, Isolate* isolate);
|
| };
|
|
|
|
|
| @@ -741,6 +758,19 @@ class CompareIC: public IC {
|
| GENERIC
|
| };
|
|
|
| + static State NewInputState(State old_state, Handle<Object> value);
|
| +
|
| + static Handle<Type> StateToType(Isolate* isolate,
|
| + State state,
|
| + Handle<Map> map = Handle<Map>());
|
| +
|
| + static void StubInfoToType(int stub_minor_key,
|
| + Handle<Type>* left_type,
|
| + Handle<Type>* right_type,
|
| + Handle<Type>* overall_type,
|
| + Handle<Map> map,
|
| + Isolate* isolate);
|
| +
|
| CompareIC(Isolate* isolate, Token::Value op)
|
| : IC(EXTRA_CALL_FRAME, isolate), op_(op) { }
|
|
|
|
|