OLD | NEW |
---|---|
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "src/v8.h" | 5 #include "src/v8.h" |
6 | 6 |
7 #if V8_TARGET_ARCH_IA32 | 7 #if V8_TARGET_ARCH_IA32 |
8 | 8 |
9 #include "src/codegen.h" | 9 #include "src/codegen.h" |
10 #include "src/deoptimizer.h" | 10 #include "src/deoptimizer.h" |
(...skipping 977 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
988 __ mov(ebx, | 988 __ mov(ebx, |
989 Operand(esi, Context::SlotOffset(Context::GLOBAL_OBJECT_INDEX))); | 989 Operand(esi, Context::SlotOffset(Context::GLOBAL_OBJECT_INDEX))); |
990 __ mov(ebx, FieldOperand(ebx, GlobalObject::kGlobalReceiverOffset)); | 990 __ mov(ebx, FieldOperand(ebx, GlobalObject::kGlobalReceiverOffset)); |
991 | 991 |
992 // Push the receiver. | 992 // Push the receiver. |
993 __ bind(&push_receiver); | 993 __ bind(&push_receiver); |
994 __ push(ebx); | 994 __ push(ebx); |
995 | 995 |
996 // Copy all arguments from the array to the stack. | 996 // Copy all arguments from the array to the stack. |
997 Label entry, loop; | 997 Label entry, loop; |
998 __ mov(ecx, Operand(ebp, kIndexOffset)); | 998 Register receiver = LoadIC::ReceiverRegister(); |
999 Register key = LoadIC::NameRegister(); | |
1000 __ mov(key, Operand(ebp, kIndexOffset)); | |
999 __ jmp(&entry); | 1001 __ jmp(&entry); |
1000 __ bind(&loop); | 1002 __ bind(&loop); |
1001 __ mov(edx, Operand(ebp, kArgumentsOffset)); // load arguments | 1003 __ mov(receiver, Operand(ebp, kArgumentsOffset)); // load arguments |
1002 | 1004 |
1003 // Use inline caching to speed up access to arguments. | 1005 // Use inline caching to speed up access to arguments. |
1004 Handle<Code> ic = masm->isolate()->builtins()->KeyedLoadIC_Initialize(); | 1006 Handle<Code> ic = masm->isolate()->builtins()->KeyedLoadIC_Initialize(); |
1005 __ call(ic, RelocInfo::CODE_TARGET); | 1007 __ call(ic, RelocInfo::CODE_TARGET); |
1006 // It is important that we do not have a test instruction after the | 1008 // It is important that we do not have a test instruction after the |
1007 // call. A test instruction after the call is used to indicate that | 1009 // call. A test instruction after the call is used to indicate that |
1008 // we have generated an inline version of the keyed load. In this | 1010 // we have generated an inline version of the keyed load. In this |
1009 // case, we know that we are not generating a test instruction next. | 1011 // case, we know that we are not generating a test instruction next. |
1010 | 1012 |
1011 // Push the nth argument. | 1013 // Push the nth argument. |
1012 __ push(eax); | 1014 __ push(eax); |
1013 | 1015 |
1014 // Update the index on the stack and in register eax. | 1016 // Update the index on the stack and in register eax. |
Jakob Kummerow
2014/06/26 16:17:10
nit: s/eax/|key|/
mvstanton
2014/06/30 13:19:09
Done.
| |
1015 __ mov(ecx, Operand(ebp, kIndexOffset)); | 1017 __ mov(key, Operand(ebp, kIndexOffset)); |
1016 __ add(ecx, Immediate(1 << kSmiTagSize)); | 1018 __ add(key, Immediate(1 << kSmiTagSize)); |
1017 __ mov(Operand(ebp, kIndexOffset), ecx); | 1019 __ mov(Operand(ebp, kIndexOffset), key); |
1018 | 1020 |
1019 __ bind(&entry); | 1021 __ bind(&entry); |
1020 __ cmp(ecx, Operand(ebp, kLimitOffset)); | 1022 __ cmp(key, Operand(ebp, kLimitOffset)); |
1021 __ j(not_equal, &loop); | 1023 __ j(not_equal, &loop); |
1022 | 1024 |
1023 // Call the function. | 1025 // Call the function. |
1024 Label call_proxy; | 1026 Label call_proxy; |
1025 __ mov(eax, ecx); | |
1026 ParameterCount actual(eax); | 1027 ParameterCount actual(eax); |
1028 ASSERT(!key.is(eax)); | |
Jakob Kummerow
2014/06/26 16:17:10
Here, too, consider using Move() instead.
mvstanton
2014/06/30 13:19:09
Done.
| |
1029 __ mov(eax, key); | |
1027 __ SmiUntag(eax); | 1030 __ SmiUntag(eax); |
1028 __ mov(edi, Operand(ebp, kFunctionOffset)); | 1031 __ mov(edi, Operand(ebp, kFunctionOffset)); |
1029 __ CmpObjectType(edi, JS_FUNCTION_TYPE, ecx); | 1032 __ CmpObjectType(edi, JS_FUNCTION_TYPE, ecx); |
1030 __ j(not_equal, &call_proxy); | 1033 __ j(not_equal, &call_proxy); |
1031 __ InvokeFunction(edi, actual, CALL_FUNCTION, NullCallWrapper()); | 1034 __ InvokeFunction(edi, actual, CALL_FUNCTION, NullCallWrapper()); |
1032 | 1035 |
1033 frame_scope.GenerateLeaveFrame(); | 1036 frame_scope.GenerateLeaveFrame(); |
1034 __ ret(3 * kPointerSize); // remove this, receiver, and arguments | 1037 __ ret(3 * kPointerSize); // remove this, receiver, and arguments |
1035 | 1038 |
1036 // Call the function proxy. | 1039 // Call the function proxy. |
(...skipping 406 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1443 | 1446 |
1444 __ bind(&ok); | 1447 __ bind(&ok); |
1445 __ ret(0); | 1448 __ ret(0); |
1446 } | 1449 } |
1447 | 1450 |
1448 #undef __ | 1451 #undef __ |
1449 } | 1452 } |
1450 } // namespace v8::internal | 1453 } // namespace v8::internal |
1451 | 1454 |
1452 #endif // V8_TARGET_ARCH_IA32 | 1455 #endif // V8_TARGET_ARCH_IA32 |
OLD | NEW |