| 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/base/bits.h" | 9 #include "src/base/bits.h" |
| 10 #include "src/code-factory.h" | 10 #include "src/code-factory.h" |
| (...skipping 3946 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3957 } | 3957 } |
| 3958 } | 3958 } |
| 3959 | 3959 |
| 3960 | 3960 |
| 3961 void LCodeGen::DoCallFunction(LCallFunction* instr) { | 3961 void LCodeGen::DoCallFunction(LCallFunction* instr) { |
| 3962 DCHECK(ToRegister(instr->context()).is(esi)); | 3962 DCHECK(ToRegister(instr->context()).is(esi)); |
| 3963 DCHECK(ToRegister(instr->function()).is(edi)); | 3963 DCHECK(ToRegister(instr->function()).is(edi)); |
| 3964 DCHECK(ToRegister(instr->result()).is(eax)); | 3964 DCHECK(ToRegister(instr->result()).is(eax)); |
| 3965 | 3965 |
| 3966 int arity = instr->arity(); | 3966 int arity = instr->arity(); |
| 3967 CallFunctionStub stub(isolate(), arity, instr->hydrogen()->function_flags()); | 3967 CallFunctionFlags flags = instr->hydrogen()->function_flags(); |
| 3968 CallCode(stub.GetCode(), RelocInfo::CODE_TARGET, instr); | 3968 if (instr->hydrogen()->HasVectorAndSlot()) { |
| 3969 Register slot_register = ToRegister(instr->temp_slot()); |
| 3970 Register vector_register = ToRegister(instr->temp_vector()); |
| 3971 DCHECK(slot_register.is(edx)); |
| 3972 DCHECK(vector_register.is(ebx)); |
| 3973 |
| 3974 Handle<TypeFeedbackVector> vector = instr->hydrogen()->feedback_vector(); |
| 3975 int index = vector->GetIndex(instr->hydrogen()->slot()); |
| 3976 |
| 3977 __ mov(vector_register, vector); |
| 3978 __ mov(slot_register, Immediate(Smi::FromInt(index))); |
| 3979 |
| 3980 CallICState::CallType call_type = |
| 3981 (flags & CALL_AS_METHOD) ? CallICState::METHOD : CallICState::FUNCTION; |
| 3982 |
| 3983 Handle<Code> ic = |
| 3984 CodeFactory::CallICInOptimizedCode(isolate(), arity, call_type).code(); |
| 3985 CallCode(ic, RelocInfo::CODE_TARGET, instr); |
| 3986 } else { |
| 3987 CallFunctionStub stub(isolate(), arity, flags); |
| 3988 CallCode(stub.GetCode(), RelocInfo::CODE_TARGET, instr); |
| 3989 } |
| 3969 } | 3990 } |
| 3970 | 3991 |
| 3971 | 3992 |
| 3972 void LCodeGen::DoCallNew(LCallNew* instr) { | 3993 void LCodeGen::DoCallNew(LCallNew* instr) { |
| 3973 DCHECK(ToRegister(instr->context()).is(esi)); | 3994 DCHECK(ToRegister(instr->context()).is(esi)); |
| 3974 DCHECK(ToRegister(instr->constructor()).is(edi)); | 3995 DCHECK(ToRegister(instr->constructor()).is(edi)); |
| 3975 DCHECK(ToRegister(instr->result()).is(eax)); | 3996 DCHECK(ToRegister(instr->result()).is(eax)); |
| 3976 | 3997 |
| 3977 // No cell in ebx for construct type feedback in optimized code | 3998 // No cell in ebx for construct type feedback in optimized code |
| 3978 __ mov(ebx, isolate()->factory()->undefined_value()); | 3999 __ mov(ebx, isolate()->factory()->undefined_value()); |
| (...skipping 1771 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 5750 CallRuntime(Runtime::kPushBlockContext, 2, instr); | 5771 CallRuntime(Runtime::kPushBlockContext, 2, instr); |
| 5751 RecordSafepoint(Safepoint::kNoLazyDeopt); | 5772 RecordSafepoint(Safepoint::kNoLazyDeopt); |
| 5752 } | 5773 } |
| 5753 | 5774 |
| 5754 | 5775 |
| 5755 #undef __ | 5776 #undef __ |
| 5756 | 5777 |
| 5757 } } // namespace v8::internal | 5778 } } // namespace v8::internal |
| 5758 | 5779 |
| 5759 #endif // V8_TARGET_ARCH_IA32 | 5780 #endif // V8_TARGET_ARCH_IA32 |
| OLD | NEW |