| Index: src/arm64/stub-cache-arm64.cc
|
| diff --git a/src/arm64/stub-cache-arm64.cc b/src/arm64/stub-cache-arm64.cc
|
| index a466b6bcab83e0fdf284f6bb5c3462efd6c94b6c..5e394c5dfec816cd697c0fb0297b95c6aad6f71c 100644
|
| --- a/src/arm64/stub-cache-arm64.cc
|
| +++ b/src/arm64/stub-cache-arm64.cc
|
| @@ -17,12 +17,9 @@ namespace internal {
|
| #define __ ACCESS_MASM(masm)
|
|
|
|
|
| -void StubCompiler::GenerateDictionaryNegativeLookup(MacroAssembler* masm,
|
| - Label* miss_label,
|
| - Register receiver,
|
| - Handle<Name> name,
|
| - Register scratch0,
|
| - Register scratch1) {
|
| +void PropertyHandlerCompiler::GenerateDictionaryNegativeLookup(
|
| + MacroAssembler* masm, Label* miss_label, Register receiver,
|
| + Handle<Name> name, Register scratch0, Register scratch1) {
|
| ASSERT(!AreAliased(receiver, scratch0, scratch1));
|
| ASSERT(name->IsUniqueName());
|
| Counters* counters = masm->isolate()->counters();
|
| @@ -201,29 +198,8 @@ void StubCache::GenerateProbe(MacroAssembler* masm,
|
| }
|
|
|
|
|
| -void StubCompiler::GenerateLoadGlobalFunctionPrototype(MacroAssembler* masm,
|
| - int index,
|
| - Register prototype) {
|
| - // Load the global or builtins object from the current context.
|
| - __ Ldr(prototype, GlobalObjectMemOperand());
|
| - // Load the native context from the global or builtins object.
|
| - __ Ldr(prototype,
|
| - FieldMemOperand(prototype, GlobalObject::kNativeContextOffset));
|
| - // Load the function from the native context.
|
| - __ Ldr(prototype, ContextMemOperand(prototype, index));
|
| - // Load the initial map. The global functions all have initial maps.
|
| - __ Ldr(prototype,
|
| - FieldMemOperand(prototype, JSFunction::kPrototypeOrInitialMapOffset));
|
| - // Load the prototype from the initial map.
|
| - __ Ldr(prototype, FieldMemOperand(prototype, Map::kPrototypeOffset));
|
| -}
|
| -
|
| -
|
| -void StubCompiler::GenerateDirectLoadGlobalFunctionPrototype(
|
| - MacroAssembler* masm,
|
| - int index,
|
| - Register prototype,
|
| - Label* miss) {
|
| +void NamedLoadHandlerCompiler::GenerateDirectLoadGlobalFunctionPrototype(
|
| + MacroAssembler* masm, int index, Register prototype, Label* miss) {
|
| Isolate* isolate = masm->isolate();
|
| // Get the global function with the given index.
|
| Handle<JSFunction> function(
|
| @@ -244,50 +220,9 @@ void StubCompiler::GenerateDirectLoadGlobalFunctionPrototype(
|
| }
|
|
|
|
|
| -void StubCompiler::GenerateFastPropertyLoad(MacroAssembler* masm,
|
| - Register dst,
|
| - Register src,
|
| - bool inobject,
|
| - int index,
|
| - Representation representation) {
|
| - ASSERT(!representation.IsDouble());
|
| - USE(representation);
|
| - if (inobject) {
|
| - int offset = index * kPointerSize;
|
| - __ Ldr(dst, FieldMemOperand(src, offset));
|
| - } else {
|
| - // Calculate the offset into the properties array.
|
| - int offset = index * kPointerSize + FixedArray::kHeaderSize;
|
| - __ Ldr(dst, FieldMemOperand(src, JSObject::kPropertiesOffset));
|
| - __ Ldr(dst, FieldMemOperand(dst, offset));
|
| - }
|
| -}
|
| -
|
| -
|
| -void StubCompiler::GenerateLoadArrayLength(MacroAssembler* masm,
|
| - Register receiver,
|
| - Register scratch,
|
| - Label* miss_label) {
|
| - ASSERT(!AreAliased(receiver, scratch));
|
| -
|
| - // Check that the receiver isn't a smi.
|
| - __ JumpIfSmi(receiver, miss_label);
|
| -
|
| - // Check that the object is a JS array.
|
| - __ JumpIfNotObjectType(receiver, scratch, scratch, JS_ARRAY_TYPE,
|
| - miss_label);
|
| -
|
| - // Load length directly from the JS array.
|
| - __ Ldr(x0, FieldMemOperand(receiver, JSArray::kLengthOffset));
|
| - __ Ret();
|
| -}
|
| -
|
| -
|
| -void StubCompiler::GenerateLoadFunctionPrototype(MacroAssembler* masm,
|
| - Register receiver,
|
| - Register scratch1,
|
| - Register scratch2,
|
| - Label* miss_label) {
|
| +void NamedLoadHandlerCompiler::GenerateLoadFunctionPrototype(
|
| + MacroAssembler* masm, Register receiver, Register scratch1,
|
| + Register scratch2, Label* miss_label) {
|
| __ TryGetFunctionPrototype(receiver, scratch1, scratch2, miss_label);
|
| // TryGetFunctionPrototype can't put the result directly in x0 because the
|
| // 3 inputs registers can't alias and we call this function from
|
| @@ -301,11 +236,9 @@ void StubCompiler::GenerateLoadFunctionPrototype(MacroAssembler* masm,
|
| // Generate code to check that a global property cell is empty. Create
|
| // the property cell at compilation time if no cell exists for the
|
| // property.
|
| -void StubCompiler::GenerateCheckPropertyCell(MacroAssembler* masm,
|
| - Handle<JSGlobalObject> global,
|
| - Handle<Name> name,
|
| - Register scratch,
|
| - Label* miss) {
|
| +void PropertyHandlerCompiler::GenerateCheckPropertyCell(
|
| + MacroAssembler* masm, Handle<JSGlobalObject> global, Handle<Name> name,
|
| + Register scratch, Label* miss) {
|
| Handle<Cell> cell = JSGlobalObject::EnsurePropertyCell(global, name);
|
| ASSERT(cell->value()->IsTheHole());
|
| __ Mov(scratch, Operand(cell));
|
| @@ -314,12 +247,9 @@ void StubCompiler::GenerateCheckPropertyCell(MacroAssembler* masm,
|
| }
|
|
|
|
|
| -void StoreStubCompiler::GenerateNegativeHolderLookup(
|
| - MacroAssembler* masm,
|
| - Handle<JSObject> holder,
|
| - Register holder_reg,
|
| - Handle<Name> name,
|
| - Label* miss) {
|
| +void NamedStoreHandlerCompiler::GenerateNegativeHolderLookup(
|
| + MacroAssembler* masm, Handle<JSObject> holder, Register holder_reg,
|
| + Handle<Name> name, Label* miss) {
|
| if (holder->IsJSGlobalObject()) {
|
| GenerateCheckPropertyCell(
|
| masm, Handle<JSGlobalObject>::cast(holder), name, scratch1(), miss);
|
| @@ -334,19 +264,11 @@ void StoreStubCompiler::GenerateNegativeHolderLookup(
|
| // When leaving generated code after success, the receiver_reg and storage_reg
|
| // may be clobbered. Upon branch to miss_label, the receiver and name registers
|
| // have their original values.
|
| -void StoreStubCompiler::GenerateStoreTransition(MacroAssembler* masm,
|
| - Handle<JSObject> object,
|
| - LookupResult* lookup,
|
| - Handle<Map> transition,
|
| - Handle<Name> name,
|
| - Register receiver_reg,
|
| - Register storage_reg,
|
| - Register value_reg,
|
| - Register scratch1,
|
| - Register scratch2,
|
| - Register scratch3,
|
| - Label* miss_label,
|
| - Label* slow) {
|
| +void NamedStoreHandlerCompiler::GenerateStoreTransition(
|
| + MacroAssembler* masm, Handle<JSObject> object, LookupResult* lookup,
|
| + Handle<Map> transition, Handle<Name> name, Register receiver_reg,
|
| + Register storage_reg, Register value_reg, Register scratch1,
|
| + Register scratch2, Register scratch3, Label* miss_label, Label* slow) {
|
| Label exit;
|
|
|
| ASSERT(!AreAliased(receiver_reg, storage_reg, value_reg,
|
| @@ -507,15 +429,10 @@ void StoreStubCompiler::GenerateStoreTransition(MacroAssembler* masm,
|
| // When leaving generated code after success, the receiver_reg and name_reg may
|
| // be clobbered. Upon branch to miss_label, the receiver and name registers have
|
| // their original values.
|
| -void StoreStubCompiler::GenerateStoreField(MacroAssembler* masm,
|
| - Handle<JSObject> object,
|
| - LookupResult* lookup,
|
| - Register receiver_reg,
|
| - Register name_reg,
|
| - Register value_reg,
|
| - Register scratch1,
|
| - Register scratch2,
|
| - Label* miss_label) {
|
| +void NamedStoreHandlerCompiler::GenerateStoreField(
|
| + MacroAssembler* masm, Handle<JSObject> object, LookupResult* lookup,
|
| + Register receiver_reg, Register name_reg, Register value_reg,
|
| + Register scratch1, Register scratch2, Label* miss_label) {
|
| // x0 : value
|
| Label exit;
|
|
|
| @@ -635,9 +552,9 @@ void StoreStubCompiler::GenerateStoreField(MacroAssembler* masm,
|
| }
|
|
|
|
|
| -void StoreStubCompiler::GenerateRestoreName(MacroAssembler* masm,
|
| - Label* label,
|
| - Handle<Name> name) {
|
| +void NamedStoreHandlerCompiler::GenerateRestoreName(MacroAssembler* masm,
|
| + Label* label,
|
| + Handle<Name> name) {
|
| if (!label->is_unused()) {
|
| __ Bind(label);
|
| __ Mov(this->name(), Operand(name));
|
| @@ -681,14 +598,10 @@ static void CompileCallLoadPropertyWithInterceptor(
|
|
|
|
|
| // Generate call to api function.
|
| -void StubCompiler::GenerateFastApiCall(MacroAssembler* masm,
|
| - const CallOptimization& optimization,
|
| - Handle<Map> receiver_map,
|
| - Register receiver,
|
| - Register scratch,
|
| - bool is_store,
|
| - int argc,
|
| - Register* values) {
|
| +void PropertyHandlerCompiler::GenerateFastApiCall(
|
| + MacroAssembler* masm, const CallOptimization& optimization,
|
| + Handle<Map> receiver_map, Register receiver, Register scratch,
|
| + bool is_store, int argc, Register* values) {
|
| ASSERT(!AreAliased(receiver, scratch));
|
|
|
| MacroAssembler::PushPopQueue queue(masm);
|
| @@ -759,7 +672,8 @@ void StubCompiler::GenerateFastApiCall(MacroAssembler* masm,
|
| }
|
|
|
|
|
| -void StubCompiler::GenerateTailCall(MacroAssembler* masm, Handle<Code> code) {
|
| +void PropertyAccessCompiler::GenerateTailCall(MacroAssembler* masm,
|
| + Handle<Code> code) {
|
| __ Jump(code, RelocInfo::CODE_TARGET);
|
| }
|
|
|
| @@ -768,15 +682,10 @@ void StubCompiler::GenerateTailCall(MacroAssembler* masm, Handle<Code> code) {
|
| #define __ ACCESS_MASM(masm())
|
|
|
|
|
| -Register StubCompiler::CheckPrototypes(Handle<HeapType> type,
|
| - Register object_reg,
|
| - Handle<JSObject> holder,
|
| - Register holder_reg,
|
| - Register scratch1,
|
| - Register scratch2,
|
| - Handle<Name> name,
|
| - Label* miss,
|
| - PrototypeCheckType check) {
|
| +Register PropertyHandlerCompiler::CheckPrototypes(
|
| + Handle<HeapType> type, Register object_reg, Handle<JSObject> holder,
|
| + Register holder_reg, Register scratch1, Register scratch2,
|
| + Handle<Name> name, Label* miss, PrototypeCheckType check) {
|
| Handle<Map> receiver_map(IC::TypeToMap(*type, isolate()));
|
|
|
| // object_reg and holder_reg registers can alias.
|
| @@ -883,7 +792,7 @@ Register StubCompiler::CheckPrototypes(Handle<HeapType> type,
|
| }
|
|
|
|
|
| -void LoadStubCompiler::HandlerFrontendFooter(Handle<Name> name, Label* miss) {
|
| +void NamedLoadHandlerCompiler::FrontendFooter(Handle<Name> name, Label* miss) {
|
| if (!miss->is_unused()) {
|
| Label success;
|
| __ B(&success);
|
| @@ -896,7 +805,7 @@ void LoadStubCompiler::HandlerFrontendFooter(Handle<Name> name, Label* miss) {
|
| }
|
|
|
|
|
| -void StoreStubCompiler::HandlerFrontendFooter(Handle<Name> name, Label* miss) {
|
| +void NamedStoreHandlerCompiler::FrontendFooter(Handle<Name> name, Label* miss) {
|
| if (!miss->is_unused()) {
|
| Label success;
|
| __ B(&success);
|
| @@ -909,15 +818,15 @@ void StoreStubCompiler::HandlerFrontendFooter(Handle<Name> name, Label* miss) {
|
| }
|
|
|
|
|
| -Register LoadStubCompiler::CallbackHandlerFrontend(Handle<HeapType> type,
|
| - Register object_reg,
|
| - Handle<JSObject> holder,
|
| - Handle<Name> name,
|
| - Handle<Object> callback) {
|
| +Register NamedLoadHandlerCompiler::CallbackFrontend(Handle<HeapType> type,
|
| + Register object_reg,
|
| + Handle<JSObject> holder,
|
| + Handle<Name> name,
|
| + Handle<Object> callback) {
|
| Label miss;
|
|
|
| - Register reg = HandlerFrontendHeader(type, object_reg, holder, name, &miss);
|
| - // HandlerFrontendHeader can return its result into scratch1() so do not
|
| + Register reg = FrontendHeader(type, object_reg, holder, name, &miss);
|
| + // FrontendHeader can return its result into scratch1() so do not
|
| // use it.
|
| Register scratch2 = this->scratch2();
|
| Register scratch3 = this->scratch3();
|
| @@ -950,31 +859,29 @@ Register LoadStubCompiler::CallbackHandlerFrontend(Handle<HeapType> type,
|
| __ B(ne, &miss);
|
| }
|
|
|
| - HandlerFrontendFooter(name, &miss);
|
| + FrontendFooter(name, &miss);
|
| return reg;
|
| }
|
|
|
|
|
| -void LoadStubCompiler::GenerateLoadField(Register reg,
|
| - Handle<JSObject> holder,
|
| - FieldIndex field,
|
| - Representation representation) {
|
| +void NamedLoadHandlerCompiler::GenerateLoadField(
|
| + Register reg, Handle<JSObject> holder, FieldIndex field,
|
| + Representation representation) {
|
| __ Mov(receiver(), reg);
|
| LoadFieldStub stub(isolate(), field);
|
| GenerateTailCall(masm(), stub.GetCode());
|
| }
|
|
|
|
|
| -void LoadStubCompiler::GenerateLoadConstant(Handle<Object> value) {
|
| +void NamedLoadHandlerCompiler::GenerateLoadConstant(Handle<Object> value) {
|
| // Return the constant value.
|
| __ LoadObject(x0, value);
|
| __ Ret();
|
| }
|
|
|
|
|
| -void LoadStubCompiler::GenerateLoadCallback(
|
| - Register reg,
|
| - Handle<ExecutableAccessorInfo> callback) {
|
| +void NamedLoadHandlerCompiler::GenerateLoadCallback(
|
| + Register reg, Handle<ExecutableAccessorInfo> callback) {
|
| ASSERT(!AreAliased(scratch2(), scratch3(), scratch4(), reg));
|
|
|
| // Build ExecutableAccessorInfo::args_ list on the stack and push property
|
| @@ -1027,11 +934,9 @@ void LoadStubCompiler::GenerateLoadCallback(
|
| }
|
|
|
|
|
| -void LoadStubCompiler::GenerateLoadInterceptor(
|
| - Register holder_reg,
|
| - Handle<Object> object,
|
| - Handle<JSObject> interceptor_holder,
|
| - LookupResult* lookup,
|
| +void NamedLoadHandlerCompiler::GenerateLoadInterceptor(
|
| + Register holder_reg, Handle<Object> object,
|
| + Handle<JSObject> interceptor_holder, LookupResult* lookup,
|
| Handle<Name> name) {
|
| ASSERT(!AreAliased(receiver(), this->name(),
|
| scratch1(), scratch2(), scratch3()));
|
| @@ -1115,14 +1020,12 @@ void LoadStubCompiler::GenerateLoadInterceptor(
|
| }
|
|
|
|
|
| -Handle<Code> StoreStubCompiler::CompileStoreCallback(
|
| - Handle<JSObject> object,
|
| - Handle<JSObject> holder,
|
| - Handle<Name> name,
|
| +Handle<Code> NamedStoreHandlerCompiler::CompileStoreCallback(
|
| + Handle<JSObject> object, Handle<JSObject> holder, Handle<Name> name,
|
| Handle<ExecutableAccessorInfo> callback) {
|
| - ASM_LOCATION("StoreStubCompiler::CompileStoreCallback");
|
| - Register holder_reg = HandlerFrontend(
|
| - IC::CurrentTypeOf(object, isolate()), receiver(), holder, name);
|
| + ASM_LOCATION("NamedStoreHandlerCompiler::CompileStoreCallback");
|
| + Register holder_reg =
|
| + Frontend(IC::CurrentTypeOf(object, isolate()), receiver(), holder, name);
|
|
|
| // Stub never generated for non-global objects that require access checks.
|
| ASSERT(holder->IsJSGlobalProxy() || !holder->IsAccessCheckNeeded());
|
| @@ -1148,10 +1051,8 @@ Handle<Code> StoreStubCompiler::CompileStoreCallback(
|
| #define __ ACCESS_MASM(masm)
|
|
|
|
|
| -void StoreStubCompiler::GenerateStoreViaSetter(
|
| - MacroAssembler* masm,
|
| - Handle<HeapType> type,
|
| - Register receiver,
|
| +void NamedStoreHandlerCompiler::GenerateStoreViaSetter(
|
| + MacroAssembler* masm, Handle<HeapType> type, Register receiver,
|
| Handle<JSFunction> setter) {
|
| // ----------- S t a t e -------------
|
| // -- lr : return address
|
| @@ -1196,12 +1097,11 @@ void StoreStubCompiler::GenerateStoreViaSetter(
|
| #define __ ACCESS_MASM(masm())
|
|
|
|
|
| -Handle<Code> StoreStubCompiler::CompileStoreInterceptor(
|
| - Handle<JSObject> object,
|
| - Handle<Name> name) {
|
| +Handle<Code> NamedStoreHandlerCompiler::CompileStoreInterceptor(
|
| + Handle<JSObject> object, Handle<Name> name) {
|
| Label miss;
|
|
|
| - ASM_LOCATION("StoreStubCompiler::CompileStoreInterceptor");
|
| + ASM_LOCATION("NamedStoreHandlerCompiler::CompileStoreInterceptor");
|
|
|
| __ Push(receiver(), this->name(), value());
|
|
|
| @@ -1215,10 +1115,9 @@ Handle<Code> StoreStubCompiler::CompileStoreInterceptor(
|
| }
|
|
|
|
|
| -Handle<Code> LoadStubCompiler::CompileLoadNonexistent(Handle<HeapType> type,
|
| - Handle<JSObject> last,
|
| - Handle<Name> name) {
|
| - NonexistentHandlerFrontend(type, last, name);
|
| +Handle<Code> NamedLoadHandlerCompiler::CompileLoadNonexistent(
|
| + Handle<HeapType> type, Handle<JSObject> last, Handle<Name> name) {
|
| + NonexistentFrontend(type, last, name);
|
|
|
| // Return undefined if maps of the full prototype chain are still the
|
| // same and no global property with this name contains a value.
|
| @@ -1231,12 +1130,13 @@ Handle<Code> LoadStubCompiler::CompileLoadNonexistent(Handle<HeapType> type,
|
|
|
|
|
| // TODO(all): The so-called scratch registers are significant in some cases. For
|
| -// example, KeyedStoreStubCompiler::registers()[3] (x3) is actually used for
|
| -// KeyedStoreCompiler::transition_map(). We should verify which registers are
|
| -// actually scratch registers, and which are important. For now, we use the same
|
| -// assignments as ARM to remain on the safe side.
|
| +// example, PropertyAccessCompiler::keyed_store_calling_convention()[3] (x3) is
|
| +// actually
|
| +// used for KeyedStoreCompiler::transition_map(). We should verify which
|
| +// registers are actually scratch registers, and which are important. For now,
|
| +// we use the same assignments as ARM to remain on the safe side.
|
|
|
| -Register* LoadStubCompiler::registers() {
|
| +Register* PropertyAccessCompiler::load_calling_convention() {
|
| // receiver, name, scratch1, scratch2, scratch3, scratch4.
|
| Register receiver = LoadIC::ReceiverRegister();
|
| Register name = LoadIC::NameRegister();
|
| @@ -1245,21 +1145,7 @@ Register* LoadStubCompiler::registers() {
|
| }
|
|
|
|
|
| -Register* KeyedLoadStubCompiler::registers() {
|
| - // receiver, name, scratch1, scratch2, scratch3, scratch4.
|
| - Register receiver = LoadIC::ReceiverRegister();
|
| - Register name = LoadIC::NameRegister();
|
| - static Register registers[] = { receiver, name, x3, x0, x4, x5 };
|
| - return registers;
|
| -}
|
| -
|
| -
|
| -Register StoreStubCompiler::value() {
|
| - return StoreIC::ValueRegister();
|
| -}
|
| -
|
| -
|
| -Register* StoreStubCompiler::registers() {
|
| +Register* PropertyAccessCompiler::store_calling_convention() {
|
| // receiver, value, scratch1, scratch2, scratch3.
|
| Register receiver = StoreIC::ReceiverRegister();
|
| Register name = StoreIC::NameRegister();
|
| @@ -1268,7 +1154,7 @@ Register* StoreStubCompiler::registers() {
|
| }
|
|
|
|
|
| -Register* KeyedStoreStubCompiler::registers() {
|
| +Register* PropertyAccessCompiler::keyed_store_calling_convention() {
|
| // receiver, name, scratch1/map, scratch2, scratch3.
|
| Register receiver = KeyedStoreIC::ReceiverRegister();
|
| Register name = KeyedStoreIC::NameRegister();
|
| @@ -1278,13 +1164,15 @@ Register* KeyedStoreStubCompiler::registers() {
|
| }
|
|
|
|
|
| +Register NamedStoreHandlerCompiler::value() { return StoreIC::ValueRegister(); }
|
| +
|
| +
|
| #undef __
|
| #define __ ACCESS_MASM(masm)
|
|
|
| -void LoadStubCompiler::GenerateLoadViaGetter(MacroAssembler* masm,
|
| - Handle<HeapType> type,
|
| - Register receiver,
|
| - Handle<JSFunction> getter) {
|
| +void NamedLoadHandlerCompiler::GenerateLoadViaGetter(
|
| + MacroAssembler* masm, Handle<HeapType> type, Register receiver,
|
| + Handle<JSFunction> getter) {
|
| {
|
| FrameScope scope(masm, StackFrame::INTERNAL);
|
|
|
| @@ -1317,14 +1205,11 @@ void LoadStubCompiler::GenerateLoadViaGetter(MacroAssembler* masm,
|
| #define __ ACCESS_MASM(masm())
|
|
|
|
|
| -Handle<Code> LoadStubCompiler::CompileLoadGlobal(
|
| - Handle<HeapType> type,
|
| - Handle<GlobalObject> global,
|
| - Handle<PropertyCell> cell,
|
| - Handle<Name> name,
|
| - bool is_dont_delete) {
|
| +Handle<Code> NamedLoadHandlerCompiler::CompileLoadGlobal(
|
| + Handle<HeapType> type, Handle<GlobalObject> global,
|
| + Handle<PropertyCell> cell, Handle<Name> name, bool is_dont_delete) {
|
| Label miss;
|
| - HandlerFrontendHeader(type, receiver(), global, name, &miss);
|
| + FrontendHeader(type, receiver(), global, name, &miss);
|
|
|
| // Get the value from the cell.
|
| __ Mov(x3, Operand(cell));
|
| @@ -1340,19 +1225,18 @@ Handle<Code> LoadStubCompiler::CompileLoadGlobal(
|
| __ Mov(x0, x4);
|
| __ Ret();
|
|
|
| - HandlerFrontendFooter(name, &miss);
|
| + FrontendFooter(name, &miss);
|
|
|
| // Return the generated code.
|
| return GetCode(kind(), Code::NORMAL, name);
|
| }
|
|
|
|
|
| -Handle<Code> BaseLoadStoreStubCompiler::CompilePolymorphicIC(
|
| - TypeHandleList* types,
|
| - CodeHandleList* handlers,
|
| - Handle<Name> name,
|
| - Code::StubType type,
|
| - IcCheckType check) {
|
| +Handle<Code> PropertyICCompiler::CompilePolymorphic(TypeHandleList* types,
|
| + CodeHandleList* handlers,
|
| + Handle<Name> name,
|
| + Code::StubType type,
|
| + IcCheckType check) {
|
| Label miss;
|
|
|
| if (check == PROPERTY &&
|
| @@ -1395,11 +1279,11 @@ Handle<Code> BaseLoadStoreStubCompiler::CompilePolymorphicIC(
|
| // Return the generated code.
|
| InlineCacheState state =
|
| (number_of_handled_maps > 1) ? POLYMORPHIC : MONOMORPHIC;
|
| - return GetICCode(kind(), type, name, state);
|
| + return GetCode(kind(), type, name, state);
|
| }
|
|
|
|
|
| -void StoreStubCompiler::GenerateStoreArrayLength() {
|
| +void NamedStoreHandlerCompiler::GenerateStoreArrayLength() {
|
| // Prepare tail call to StoreIC_ArrayLength.
|
| __ Push(receiver(), value());
|
|
|
| @@ -1410,13 +1294,12 @@ void StoreStubCompiler::GenerateStoreArrayLength() {
|
| }
|
|
|
|
|
| -Handle<Code> KeyedStoreStubCompiler::CompileStorePolymorphic(
|
| - MapHandleList* receiver_maps,
|
| - CodeHandleList* handler_stubs,
|
| +Handle<Code> PropertyICCompiler::CompileIndexedStorePolymorphic(
|
| + MapHandleList* receiver_maps, CodeHandleList* handler_stubs,
|
| MapHandleList* transitioned_maps) {
|
| Label miss;
|
|
|
| - ASM_LOCATION("KeyedStoreStubCompiler::CompileStorePolymorphic");
|
| + ASM_LOCATION("PropertyICCompiler::CompileStorePolymorphic");
|
|
|
| __ JumpIfSmi(receiver(), &miss);
|
|
|
| @@ -1439,15 +1322,14 @@ Handle<Code> KeyedStoreStubCompiler::CompileStorePolymorphic(
|
| __ Bind(&miss);
|
| TailCallBuiltin(masm(), MissBuiltin(kind()));
|
|
|
| - return GetICCode(
|
| - kind(), Code::NORMAL, factory()->empty_string(), POLYMORPHIC);
|
| + return GetCode(kind(), Code::NORMAL, factory()->empty_string(), POLYMORPHIC);
|
| }
|
|
|
|
|
| #undef __
|
| #define __ ACCESS_MASM(masm)
|
|
|
| -void KeyedLoadStubCompiler::GenerateLoadDictionaryElement(
|
| +void IndexedHandlerCompiler::GenerateLoadDictionaryElement(
|
| MacroAssembler* masm) {
|
| // The return address is in lr.
|
| Label slow, miss;
|
|
|