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(); |