Index: src/arm/stub-cache-arm.cc |
diff --git a/src/arm/stub-cache-arm.cc b/src/arm/stub-cache-arm.cc |
index e02281f1b699a6c8712b4c5e42e3797f74b7c073..abf2f643cd3872a12056da27f038b2c1de8194fb 100644 |
--- a/src/arm/stub-cache-arm.cc |
+++ b/src/arm/stub-cache-arm.cc |
@@ -864,6 +864,55 @@ Object* CallStubCompiler::CompileArrayPushCall(Object* object, |
} |
+Object* CallStubCompiler::CompileArrayPopCall(Object* object, |
+ JSObject* holder, |
+ JSFunction* function, |
+ String* name, |
+ CheckType check) { |
+ // ----------- S t a t e ------------- |
+ // -- r2 : name |
+ // -- lr : return address |
+ // ----------------------------------- |
+ |
+ // TODO(642): faster implementation. |
+ ASSERT(check == RECEIVER_MAP_CHECK); |
+ |
+ Label miss; |
+ |
+ // Get the receiver from the stack |
+ const int argc = arguments().immediate(); |
+ __ ldr(r1, MemOperand(sp, argc * kPointerSize)); |
+ |
+ // Check that the receiver isn't a smi. |
+ __ tst(r1, Operand(kSmiTagMask)); |
+ __ b(eq, &miss); |
+ |
+ // Check that the maps haven't changed. |
+ CheckPrototypes(JSObject::cast(object), r1, holder, r3, r0, name, &miss); |
+ |
+ if (object->IsGlobalObject()) { |
+ __ ldr(r3, FieldMemOperand(r1, GlobalObject::kGlobalReceiverOffset)); |
+ __ str(r3, MemOperand(sp, argc * kPointerSize)); |
+ } |
+ |
+ __ TailCallExternalReference(ExternalReference(Builtins::c_ArrayPop), |
+ argc + 1, |
+ 1); |
+ |
+ // Handle call cache miss. |
+ __ bind(&miss); |
+ Handle<Code> ic = ComputeCallMiss(arguments().immediate()); |
+ __ Jump(ic, RelocInfo::CODE_TARGET); |
+ |
+ // Return the generated code. |
+ String* function_name = NULL; |
+ if (function->shared()->name()->IsString()) { |
+ function_name = String::cast(function->shared()->name()); |
+ } |
+ return GetCode(CONSTANT_FUNCTION, function_name); |
+} |
+ |
+ |
Object* CallStubCompiler::CompileCallConstant(Object* object, |
JSObject* holder, |
JSFunction* function, |