OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
(...skipping 2933 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2944 | 2944 |
2945 __ bind(&done); | 2945 __ bind(&done); |
2946 context()->Plug(r0); | 2946 context()->Plug(r0); |
2947 } | 2947 } |
2948 | 2948 |
2949 | 2949 |
2950 void FullCodeGenerator::EmitDateField(CallRuntime* expr) { | 2950 void FullCodeGenerator::EmitDateField(CallRuntime* expr) { |
2951 ZoneList<Expression*>* args = expr->arguments(); | 2951 ZoneList<Expression*>* args = expr->arguments(); |
2952 ASSERT(args->length() == 2); | 2952 ASSERT(args->length() == 2); |
2953 ASSERT_NE(NULL, args->at(1)->AsLiteral()); | 2953 ASSERT_NE(NULL, args->at(1)->AsLiteral()); |
2954 int index = Smi::cast(*(args->at(1)->AsLiteral()->handle()))->value(); | 2954 Smi* index = Smi::cast(*(args->at(1)->AsLiteral()->handle())); |
2955 | 2955 |
2956 VisitForAccumulatorValue(args->at(0)); // Load the object. | 2956 VisitForAccumulatorValue(args->at(0)); // Load the object. |
2957 | 2957 |
| 2958 Label runtime, done; |
| 2959 Register object = r0; |
| 2960 Register result = r0; |
| 2961 Register scratch0 = r9; |
| 2962 Register scratch1 = r1; |
| 2963 |
2958 #ifdef DEBUG | 2964 #ifdef DEBUG |
2959 __ AbortIfSmi(r0); | 2965 __ AbortIfSmi(object); |
2960 __ CompareObjectType(r0, r1, r1, JS_DATE_TYPE); | 2966 __ CompareObjectType(object, scratch1, scratch1, JS_DATE_TYPE); |
2961 __ Assert(eq, "Trying to get date field from non-date."); | 2967 __ Assert(eq, "Trying to get date field from non-date."); |
2962 #endif | 2968 #endif |
2963 | 2969 |
2964 __ ldr(r0, FieldMemOperand(r0, JSDate::kValueOffset + kPointerSize * index)); | 2970 if (index->value() == 0) { |
| 2971 __ ldr(result, FieldMemOperand(object, JSDate::kValueOffset)); |
| 2972 } else { |
| 2973 if (index->value() < JSDate::kFirstUncachedField) { |
| 2974 ExternalReference stamp = ExternalReference::date_cache_stamp(isolate()); |
| 2975 __ mov(scratch1, Operand(stamp)); |
| 2976 __ ldr(scratch1, MemOperand(scratch1)); |
| 2977 __ ldr(scratch0, FieldMemOperand(object, JSDate::kCacheStampOffset)); |
| 2978 __ cmp(scratch1, scratch0); |
| 2979 __ b(ne, &runtime); |
| 2980 __ ldr(result, FieldMemOperand(object, JSDate::kValueOffset + |
| 2981 kPointerSize * index->value())); |
| 2982 __ jmp(&done); |
| 2983 } |
| 2984 __ bind(&runtime); |
| 2985 __ PrepareCallCFunction(2, scratch1); |
| 2986 __ mov(r1, Operand(index)); |
| 2987 __ CallCFunction(ExternalReference::get_date_field_function(isolate()), 2); |
| 2988 __ bind(&done); |
| 2989 } |
2965 context()->Plug(r0); | 2990 context()->Plug(r0); |
2966 } | 2991 } |
2967 | 2992 |
2968 | 2993 |
2969 void FullCodeGenerator::EmitMathPow(CallRuntime* expr) { | 2994 void FullCodeGenerator::EmitMathPow(CallRuntime* expr) { |
2970 // Load the arguments on the stack and call the runtime function. | 2995 // Load the arguments on the stack and call the runtime function. |
2971 ZoneList<Expression*>* args = expr->arguments(); | 2996 ZoneList<Expression*>* args = expr->arguments(); |
2972 ASSERT(args->length() == 2); | 2997 ASSERT(args->length() == 2); |
2973 VisitForStackValue(args->at(0)); | 2998 VisitForStackValue(args->at(0)); |
2974 VisitForStackValue(args->at(1)); | 2999 VisitForStackValue(args->at(1)); |
(...skipping 28 matching lines...) Expand all Loading... |
3003 // overwritten by the write barrier code and is needed afterward. | 3028 // overwritten by the write barrier code and is needed afterward. |
3004 __ mov(r2, r0); | 3029 __ mov(r2, r0); |
3005 __ RecordWriteField( | 3030 __ RecordWriteField( |
3006 r1, JSValue::kValueOffset, r2, r3, kLRHasBeenSaved, kDontSaveFPRegs); | 3031 r1, JSValue::kValueOffset, r2, r3, kLRHasBeenSaved, kDontSaveFPRegs); |
3007 | 3032 |
3008 __ bind(&done); | 3033 __ bind(&done); |
3009 context()->Plug(r0); | 3034 context()->Plug(r0); |
3010 } | 3035 } |
3011 | 3036 |
3012 | 3037 |
3013 void FullCodeGenerator::EmitSetDateField(CallRuntime* expr) { | |
3014 ZoneList<Expression*>* args = expr->arguments(); | |
3015 ASSERT(args->length() == 3); | |
3016 ASSERT_NE(NULL, args->at(1)->AsLiteral()); | |
3017 int index = Smi::cast(*(args->at(1)->AsLiteral()->handle()))->value(); | |
3018 | |
3019 VisitForStackValue(args->at(0)); // Load the object. | |
3020 VisitForAccumulatorValue(args->at(2)); // Load the value. | |
3021 __ pop(r1); // r0 = value. r1 = object. | |
3022 | |
3023 #ifdef DEBUG | |
3024 __ AbortIfSmi(r1); | |
3025 __ CompareObjectType(r1, r2, r2, JS_DATE_TYPE); | |
3026 __ Assert(eq, "Trying to get date field from non-date."); | |
3027 #endif | |
3028 | |
3029 // Store the value. | |
3030 __ str(r0, FieldMemOperand(r1, JSDate::kValueOffset + kPointerSize * index)); | |
3031 // Caches can only be smi or NaN, so we can skip the write barrier for them. | |
3032 if (index < JSDate::kFirstBarrierFree) { | |
3033 // Update the write barrier. Save the value as it will be | |
3034 // overwritten by the write barrier code and is needed afterward. | |
3035 __ mov(r2, r0); | |
3036 __ RecordWriteField( | |
3037 r1, JSDate::kValueOffset + kPointerSize * index, | |
3038 r2, r3, kLRHasBeenSaved, kDontSaveFPRegs); | |
3039 } | |
3040 context()->Plug(r0); | |
3041 } | |
3042 | |
3043 | |
3044 void FullCodeGenerator::EmitNumberToString(CallRuntime* expr) { | 3038 void FullCodeGenerator::EmitNumberToString(CallRuntime* expr) { |
3045 ZoneList<Expression*>* args = expr->arguments(); | 3039 ZoneList<Expression*>* args = expr->arguments(); |
3046 ASSERT_EQ(args->length(), 1); | 3040 ASSERT_EQ(args->length(), 1); |
3047 // Load the argument on the stack and call the stub. | 3041 // Load the argument on the stack and call the stub. |
3048 VisitForStackValue(args->at(0)); | 3042 VisitForStackValue(args->at(0)); |
3049 | 3043 |
3050 NumberToStringStub stub; | 3044 NumberToStringStub stub; |
3051 __ CallStub(&stub); | 3045 __ CallStub(&stub); |
3052 context()->Plug(r0); | 3046 context()->Plug(r0); |
3053 } | 3047 } |
(...skipping 1401 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
4455 *context_length = 0; | 4449 *context_length = 0; |
4456 return previous_; | 4450 return previous_; |
4457 } | 4451 } |
4458 | 4452 |
4459 | 4453 |
4460 #undef __ | 4454 #undef __ |
4461 | 4455 |
4462 } } // namespace v8::internal | 4456 } } // namespace v8::internal |
4463 | 4457 |
4464 #endif // V8_TARGET_ARCH_ARM | 4458 #endif // V8_TARGET_ARCH_ARM |
OLD | NEW |