Chromium Code Reviews| Index: src/arm/full-codegen-arm.cc |
| diff --git a/src/arm/full-codegen-arm.cc b/src/arm/full-codegen-arm.cc |
| index 418e0c5f7c9cfbcfba491a0b1021e1f95492a9dd..8ea0d5888d5f43dd1169daf98e54af5adffb9303 100644 |
| --- a/src/arm/full-codegen-arm.cc |
| +++ b/src/arm/full-codegen-arm.cc |
| @@ -2933,6 +2933,50 @@ void FullCodeGenerator::EmitValueOf(CallRuntime* expr) { |
| } |
| +void FullCodeGenerator::EmitDateField(CallRuntime* expr) { |
| + ZoneList<Expression*>* args = expr->arguments(); |
| + ASSERT(args->length() == 2); |
| + ASSERT_NE(NULL, args->at(1)->AsLiteral()); |
| + Smi* index = Smi::cast(*(args->at(1)->AsLiteral()->handle())); |
|
rossberg
2012/03/06 15:55:50
Why did you change this? It requires more redundan
ulan
2012/03/07 10:55:21
In other platforms, index is pushed onto stack bef
|
| + |
| + VisitForAccumulatorValue(args->at(0)); // Load the object. |
| + |
| + Label runtime, done; |
| + Register object = r0; |
| + Register result = r0; |
| + Register scratch0 = r9; |
| + Register scratch1 = r1; |
| + |
| +#ifdef DEBUG |
| + __ AbortIfSmi(r0); |
| + __ CompareObjectType(r0, r1, r1, JS_DATE_TYPE); |
| + __ Assert(eq, "Trying to get date field from non-date."); |
| +#endif |
| + |
| + if (index->value() == 0) { |
| + __ ldr(result, FieldMemOperand(object, JSDate::kValueOffset)); |
| + } else { |
| + if (index->value() < JSDate::kFirstUncachedField) { |
| + ExternalReference stamp = ExternalReference::date_cache_stamp(isolate()); |
| + __ mov(scratch1, Operand(stamp)); |
| + __ ldr(scratch1, MemOperand(scratch1)); |
| + __ ldr(scratch0, FieldMemOperand(object, JSDate::kCacheStampOffset)); |
| + __ cmp(scratch1, scratch0); |
| + __ b(ne, &runtime); |
| + __ ldr(result, FieldMemOperand(object, JSDate::kValueOffset + |
| + kPointerSize * index->value())); |
| + __ jmp(&done); |
| + } |
| + __ bind(&runtime); |
| + __ PrepareCallCFunction(2, scratch1); |
| + __ mov(r1, Operand(index)); |
| + __ CallCFunction(ExternalReference::get_date_field_function(isolate()), 2); |
| + __ bind(&done); |
| + } |
| + context()->Plug(r0); |
| +} |
| + |
| + |
| void FullCodeGenerator::EmitMathPow(CallRuntime* expr) { |
| // Load the arguments on the stack and call the runtime function. |
| ZoneList<Expression*>* args = expr->arguments(); |