Commit 569d9c59 authored by verwaest@chromium.org's avatar verwaest@chromium.org

Refactoring Store ICs. A first step towards polymorphic store ICs.

Review URL: https://chromiumcodereview.appspot.com/12781004

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@13934 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 8db737a5
...@@ -4513,7 +4513,7 @@ void ArrayLengthStub::Generate(MacroAssembler* masm) { ...@@ -4513,7 +4513,7 @@ void ArrayLengthStub::Generate(MacroAssembler* masm) {
StubCompiler::GenerateLoadArrayLength(masm, receiver, r3, &miss); StubCompiler::GenerateLoadArrayLength(masm, receiver, r3, &miss);
__ bind(&miss); __ bind(&miss);
StubCompiler::GenerateLoadMiss(masm, kind()); StubCompiler::TailCallBuiltin(masm, StubCompiler::MissBuiltin(kind()));
} }
...@@ -4542,7 +4542,7 @@ void FunctionPrototypeStub::Generate(MacroAssembler* masm) { ...@@ -4542,7 +4542,7 @@ void FunctionPrototypeStub::Generate(MacroAssembler* masm) {
StubCompiler::GenerateLoadFunctionPrototype(masm, receiver, r3, r4, &miss); StubCompiler::GenerateLoadFunctionPrototype(masm, receiver, r3, r4, &miss);
__ bind(&miss); __ bind(&miss);
StubCompiler::GenerateLoadMiss(masm, kind()); StubCompiler::TailCallBuiltin(masm, StubCompiler::MissBuiltin(kind()));
} }
...@@ -4573,7 +4573,7 @@ void StringLengthStub::Generate(MacroAssembler* masm) { ...@@ -4573,7 +4573,7 @@ void StringLengthStub::Generate(MacroAssembler* masm) {
support_wrapper_); support_wrapper_);
__ bind(&miss); __ bind(&miss);
StubCompiler::GenerateLoadMiss(masm, kind()); StubCompiler::TailCallBuiltin(masm, StubCompiler::MissBuiltin(kind()));
} }
...@@ -4643,7 +4643,7 @@ void StoreArrayLengthStub::Generate(MacroAssembler* masm) { ...@@ -4643,7 +4643,7 @@ void StoreArrayLengthStub::Generate(MacroAssembler* masm) {
__ bind(&miss); __ bind(&miss);
StubCompiler::GenerateStoreMiss(masm, kind()); StubCompiler::TailCallBuiltin(masm, StubCompiler::MissBuiltin(kind()));
} }
......
This diff is collapsed.
...@@ -3301,7 +3301,7 @@ void ArrayLengthStub::Generate(MacroAssembler* masm) { ...@@ -3301,7 +3301,7 @@ void ArrayLengthStub::Generate(MacroAssembler* masm) {
StubCompiler::GenerateLoadArrayLength(masm, edx, eax, &miss); StubCompiler::GenerateLoadArrayLength(masm, edx, eax, &miss);
__ bind(&miss); __ bind(&miss);
StubCompiler::GenerateLoadMiss(masm, kind()); StubCompiler::TailCallBuiltin(masm, StubCompiler::MissBuiltin(kind()));
} }
...@@ -3320,7 +3320,7 @@ void FunctionPrototypeStub::Generate(MacroAssembler* masm) { ...@@ -3320,7 +3320,7 @@ void FunctionPrototypeStub::Generate(MacroAssembler* masm) {
StubCompiler::GenerateLoadFunctionPrototype(masm, edx, eax, ebx, &miss); StubCompiler::GenerateLoadFunctionPrototype(masm, edx, eax, ebx, &miss);
__ bind(&miss); __ bind(&miss);
StubCompiler::GenerateLoadMiss(masm, kind()); StubCompiler::TailCallBuiltin(masm, StubCompiler::MissBuiltin(kind()));
} }
...@@ -3340,7 +3340,7 @@ void StringLengthStub::Generate(MacroAssembler* masm) { ...@@ -3340,7 +3340,7 @@ void StringLengthStub::Generate(MacroAssembler* masm) {
StubCompiler::GenerateLoadStringLength(masm, edx, eax, ebx, &miss, StubCompiler::GenerateLoadStringLength(masm, edx, eax, ebx, &miss,
support_wrapper_); support_wrapper_);
__ bind(&miss); __ bind(&miss);
StubCompiler::GenerateLoadMiss(masm, kind()); StubCompiler::TailCallBuiltin(masm, StubCompiler::MissBuiltin(kind()));
} }
...@@ -3404,7 +3404,7 @@ void StoreArrayLengthStub::Generate(MacroAssembler* masm) { ...@@ -3404,7 +3404,7 @@ void StoreArrayLengthStub::Generate(MacroAssembler* masm) {
__ bind(&miss); __ bind(&miss);
StubCompiler::GenerateStoreMiss(masm, kind()); StubCompiler::TailCallBuiltin(masm, StubCompiler::MissBuiltin(kind()));
} }
......
This diff is collapsed.
...@@ -139,6 +139,7 @@ class PositionsRecorder; ...@@ -139,6 +139,7 @@ class PositionsRecorder;
V(REG_EXP_TAG, "RegExp") \ V(REG_EXP_TAG, "RegExp") \
V(SCRIPT_TAG, "Script") \ V(SCRIPT_TAG, "Script") \
V(STORE_IC_TAG, "StoreIC") \ V(STORE_IC_TAG, "StoreIC") \
V(STORE_POLYMORPHIC_IC_TAG, "StorePolymorphicIC") \
V(STUB_TAG, "Stub") \ V(STUB_TAG, "Stub") \
V(NATIVE_FUNCTION_TAG, "Function") \ V(NATIVE_FUNCTION_TAG, "Function") \
V(NATIVE_LAZY_COMPILE_TAG, "LazyCompile") \ V(NATIVE_LAZY_COMPILE_TAG, "LazyCompile") \
......
This diff is collapsed.
...@@ -80,12 +80,15 @@ class StubCache { ...@@ -80,12 +80,15 @@ class StubCache {
Handle<Code> FindIC(Handle<Name> name, Handle<Code> FindIC(Handle<Name> name,
Handle<JSObject> stub_holder, Handle<JSObject> stub_holder,
Code::Kind kind, Code::Kind kind,
Code::StubType type); Code::StubType type,
Code::ExtraICState extra_state = Code::kNoExtraICState);
Handle<Code> FindStub(Handle<Name> name, Handle<Code> FindHandler(
Handle<Name> name,
Handle<JSObject> stub_holder, Handle<JSObject> stub_holder,
Code::Kind kind, Code::Kind kind,
Code::StubType type); Code::StubType type,
Code::ExtraICState extra_state = Code::kNoExtraICState);
Handle<Code> ComputeMonomorphicIC(Handle<JSObject> receiver, Handle<Code> ComputeMonomorphicIC(Handle<JSObject> receiver,
Handle<Code> handler, Handle<Code> handler,
...@@ -513,14 +516,23 @@ class StubCompiler BASE_EMBEDDED { ...@@ -513,14 +516,23 @@ class StubCompiler BASE_EMBEDDED {
Handle<Name> name, Handle<Name> name,
Register receiver_reg, Register receiver_reg,
Register name_reg, Register name_reg,
Register value_reg,
Register scratch1, Register scratch1,
Register scratch2, Register scratch2,
Label* miss_label); Label* miss_label,
Label* miss_restore_name);
static void GenerateLoadMiss(MacroAssembler* masm, Code::Kind kind);
static void GenerateStoreMiss(MacroAssembler* masm, Code::Kind kind); static Builtins::Name MissBuiltin(Code::Kind kind) {
switch (kind) {
static void GenerateKeyedLoadMissForceGeneric(MacroAssembler* masm); case Code::LOAD_IC: return Builtins::kLoadIC_Miss;
case Code::STORE_IC: return Builtins::kStoreIC_Miss;
case Code::KEYED_LOAD_IC: return Builtins::kKeyedLoadIC_Miss;
case Code::KEYED_STORE_IC: return Builtins::kKeyedStoreIC_Miss;
default: UNREACHABLE();
}
return Builtins::kLoadIC_Miss;
}
static void TailCallBuiltin(MacroAssembler* masm, Builtins::Name name);
// Generates code that verifies that the property holder has not changed // Generates code that verifies that the property holder has not changed
// (checking maps of objects in the prototype chain for fast and global // (checking maps of objects in the prototype chain for fast and global
...@@ -577,7 +589,7 @@ class StubCompiler BASE_EMBEDDED { ...@@ -577,7 +589,7 @@ class StubCompiler BASE_EMBEDDED {
Heap* heap() { return isolate()->heap(); } Heap* heap() { return isolate()->heap(); }
Factory* factory() { return isolate()->factory(); } Factory* factory() { return isolate()->factory(); }
void GenerateTailCall(Handle<Code> code); static void GenerateTailCall(MacroAssembler* masm, Handle<Code> code);
private: private:
Isolate* isolate_; Isolate* isolate_;
...@@ -739,8 +751,6 @@ class KeyedLoadStubCompiler: public BaseLoadStubCompiler { ...@@ -739,8 +751,6 @@ class KeyedLoadStubCompiler: public BaseLoadStubCompiler {
void CompileElementHandlers(MapHandleList* receiver_maps, void CompileElementHandlers(MapHandleList* receiver_maps,
CodeHandleList* handlers); CodeHandleList* handlers);
Handle<Code> CompileLoadElementPolymorphic(MapHandleList* receiver_maps);
static void GenerateLoadDictionaryElement(MacroAssembler* masm); static void GenerateLoadDictionaryElement(MacroAssembler* masm);
static Register receiver() { return registers()[0]; } static Register receiver() { return registers()[0]; }
...@@ -760,17 +770,63 @@ class KeyedLoadStubCompiler: public BaseLoadStubCompiler { ...@@ -760,17 +770,63 @@ class KeyedLoadStubCompiler: public BaseLoadStubCompiler {
}; };
class StoreStubCompiler: public StubCompiler { class BaseStoreStubCompiler: public StubCompiler {
public: public:
StoreStubCompiler(Isolate* isolate, StrictModeFlag strict_mode) BaseStoreStubCompiler(Isolate* isolate,
: StubCompiler(isolate), strict_mode_(strict_mode) { } StrictModeFlag strict_mode,
Register* registers)
: StubCompiler(isolate),
strict_mode_(strict_mode),
registers_(registers) { }
virtual ~BaseStoreStubCompiler() { }
Handle<Code> CompileStoreField(Handle<JSObject> object, Handle<Code> CompileStoreField(Handle<JSObject> object,
int index, int index,
Handle<Map> transition, Handle<Map> transition,
Handle<Name> name); Handle<Name> name);
protected:
Handle<Code> GetICCode(Code::Kind kind,
Code::StubType type,
Handle<Name> name,
InlineCacheState state = MONOMORPHIC);
Handle<Code> GetCode(Code::Kind kind,
Code::StubType type,
Handle<Name> name);
void GenerateRestoreName(MacroAssembler* masm,
Label* label,
Handle<Name> name);
Register receiver() { return registers_[0]; }
Register name() { return registers_[1]; }
Register value() { return registers_[2]; }
Register scratch1() { return registers_[3]; }
Register scratch2() { return registers_[4]; }
Register scratch3() { return registers_[5]; }
StrictModeFlag strict_mode() { return strict_mode_; }
virtual Code::ExtraICState extra_state() { return strict_mode_; }
private:
virtual Code::Kind kind() = 0;
virtual Logger::LogEventsAndTags log_kind(Handle<Code> code) = 0;
virtual void JitEvent(Handle<Name> name, Handle<Code> code) = 0;
virtual void GenerateNameCheck(Handle<Name> name,
Register name_reg,
Label* miss) { }
StrictModeFlag strict_mode_;
Register* registers_;
};
class StoreStubCompiler: public BaseStoreStubCompiler {
public:
StoreStubCompiler(Isolate* isolate, StrictModeFlag strict_mode)
: BaseStoreStubCompiler(isolate, strict_mode, registers()) { }
Handle<Code> CompileStoreCallback(Handle<Name> name, Handle<Code> CompileStoreCallback(Handle<Name> name,
Handle<JSObject> object, Handle<JSObject> object,
Handle<JSObject> holder, Handle<JSObject> holder,
...@@ -792,26 +848,25 @@ class StoreStubCompiler: public StubCompiler { ...@@ -792,26 +848,25 @@ class StoreStubCompiler: public StubCompiler {
Handle<Name> name); Handle<Name> name);
private: private:
Handle<Code> GetCode(Code::StubType type, Handle<Name> name); static Register* registers();
virtual Code::Kind kind() { return Code::STORE_IC; }
StrictModeFlag strict_mode_; virtual Logger::LogEventsAndTags log_kind(Handle<Code> code) {
if (!code->is_inline_cache_stub()) return Logger::STUB_TAG;
return code->ic_state() == MONOMORPHIC
? Logger::STORE_IC_TAG : Logger::STORE_POLYMORPHIC_IC_TAG;
}
virtual void JitEvent(Handle<Name> name, Handle<Code> code);
}; };
class KeyedStoreStubCompiler: public StubCompiler { class KeyedStoreStubCompiler: public BaseStoreStubCompiler {
public: public:
KeyedStoreStubCompiler(Isolate* isolate, KeyedStoreStubCompiler(Isolate* isolate,
StrictModeFlag strict_mode, StrictModeFlag strict_mode,
KeyedAccessStoreMode store_mode) KeyedAccessStoreMode store_mode)
: StubCompiler(isolate), : BaseStoreStubCompiler(isolate, strict_mode, registers()),
strict_mode_(strict_mode),
store_mode_(store_mode) { } store_mode_(store_mode) { }
Handle<Code> CompileStoreField(Handle<JSObject> object,
int index,
Handle<Map> transition,
Handle<Name> name);
Handle<Code> CompileStoreElement(Handle<Map> receiver_map); Handle<Code> CompileStoreElement(Handle<Map> receiver_map);
Handle<Code> CompileStorePolymorphic(MapHandleList* receiver_maps, Handle<Code> CompileStorePolymorphic(MapHandleList* receiver_maps,
...@@ -834,12 +889,23 @@ class KeyedStoreStubCompiler: public StubCompiler { ...@@ -834,12 +889,23 @@ class KeyedStoreStubCompiler: public StubCompiler {
static void GenerateStoreDictionaryElement(MacroAssembler* masm); static void GenerateStoreDictionaryElement(MacroAssembler* masm);
private: protected:
Handle<Code> GetCode(Code::StubType type, virtual Code::ExtraICState extra_state() {
Handle<Name> name, return Code::ComputeExtraICState(store_mode_, strict_mode());
InlineCacheState state = MONOMORPHIC); }
StrictModeFlag strict_mode_; private:
static Register* registers();
virtual Code::Kind kind() { return Code::KEYED_STORE_IC; }
virtual Logger::LogEventsAndTags log_kind(Handle<Code> code) {
if (!code->is_inline_cache_stub()) return Logger::STUB_TAG;
return code->ic_state() == MONOMORPHIC
? Logger::KEYED_STORE_IC_TAG : Logger::KEYED_STORE_POLYMORPHIC_IC_TAG;
}
virtual void JitEvent(Handle<Name> name, Handle<Code> code);
virtual void GenerateNameCheck(Handle<Name> name,
Register name_reg,
Label* miss);
KeyedAccessStoreMode store_mode_; KeyedAccessStoreMode store_mode_;
}; };
......
...@@ -2403,7 +2403,7 @@ void ArrayLengthStub::Generate(MacroAssembler* masm) { ...@@ -2403,7 +2403,7 @@ void ArrayLengthStub::Generate(MacroAssembler* masm) {
StubCompiler::GenerateLoadArrayLength(masm, receiver, r8, &miss); StubCompiler::GenerateLoadArrayLength(masm, receiver, r8, &miss);
__ bind(&miss); __ bind(&miss);
StubCompiler::GenerateLoadMiss(masm, kind()); StubCompiler::TailCallBuiltin(masm, StubCompiler::MissBuiltin(kind()));
} }
...@@ -2431,7 +2431,7 @@ void FunctionPrototypeStub::Generate(MacroAssembler* masm) { ...@@ -2431,7 +2431,7 @@ void FunctionPrototypeStub::Generate(MacroAssembler* masm) {
StubCompiler::GenerateLoadFunctionPrototype(masm, receiver, r8, r9, &miss); StubCompiler::GenerateLoadFunctionPrototype(masm, receiver, r8, r9, &miss);
__ bind(&miss); __ bind(&miss);
StubCompiler::GenerateLoadMiss(masm, kind()); StubCompiler::TailCallBuiltin(masm, StubCompiler::MissBuiltin(kind()));
} }
...@@ -2460,7 +2460,7 @@ void StringLengthStub::Generate(MacroAssembler* masm) { ...@@ -2460,7 +2460,7 @@ void StringLengthStub::Generate(MacroAssembler* masm) {
StubCompiler::GenerateLoadStringLength(masm, receiver, r8, r9, &miss, StubCompiler::GenerateLoadStringLength(masm, receiver, r8, r9, &miss,
support_wrapper_); support_wrapper_);
__ bind(&miss); __ bind(&miss);
StubCompiler::GenerateLoadMiss(masm, kind()); StubCompiler::TailCallBuiltin(masm, StubCompiler::MissBuiltin(kind()));
} }
...@@ -2523,7 +2523,7 @@ void StoreArrayLengthStub::Generate(MacroAssembler* masm) { ...@@ -2523,7 +2523,7 @@ void StoreArrayLengthStub::Generate(MacroAssembler* masm) {
__ bind(&miss); __ bind(&miss);
StubCompiler::GenerateStoreMiss(masm, kind()); StubCompiler::TailCallBuiltin(masm, StubCompiler::MissBuiltin(kind()));
} }
......
...@@ -1333,8 +1333,7 @@ void LoadIC::GenerateMegamorphic(MacroAssembler* masm) { ...@@ -1333,8 +1333,7 @@ void LoadIC::GenerateMegamorphic(MacroAssembler* masm) {
Isolate::Current()->stub_cache()->GenerateProbe( Isolate::Current()->stub_cache()->GenerateProbe(
masm, flags, rax, rcx, rbx, rdx); masm, flags, rax, rcx, rbx, rdx);
// Cache miss: Jump to runtime. GenerateMiss(masm);
StubCompiler::GenerateLoadMiss(masm, Code::LOAD_IC);
} }
......
This diff is collapsed.
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment