Index: src/ic/arm64/handler-compiler-arm64.cc |
diff --git a/src/ic/arm64/handler-compiler-arm64.cc b/src/ic/arm64/handler-compiler-arm64.cc |
index 8044ffbab6e95209123e70fbf0d1a24b6f36bf57..20391c7b5d7f2d48bb650de66b8c28e9ef43d0d0 100644 |
--- a/src/ic/arm64/handler-compiler-arm64.cc |
+++ b/src/ic/arm64/handler-compiler-arm64.cc |
@@ -198,11 +198,17 @@ void PropertyHandlerCompiler::GenerateApiAccessorCall( |
call_data_undefined = true; |
__ LoadRoot(data, Heap::kUndefinedValueRootIndex); |
} else { |
- __ Ldr(data, |
- FieldMemOperand(callee, JSFunction::kSharedFunctionInfoOffset)); |
- __ Ldr(data, |
- FieldMemOperand(data, SharedFunctionInfo::kFunctionDataOffset)); |
- __ Ldr(data, FieldMemOperand(data, FunctionTemplateInfo::kCallCodeOffset)); |
+ if (optimization.is_constant_call()) { |
+ __ Ldr(data, |
+ FieldMemOperand(callee, JSFunction::kSharedFunctionInfoOffset)); |
+ __ Ldr(data, |
+ FieldMemOperand(data, SharedFunctionInfo::kFunctionDataOffset)); |
+ __ Ldr(data, |
+ FieldMemOperand(data, FunctionTemplateInfo::kCallCodeOffset)); |
+ } else { |
+ __ Ldr(data, |
+ FieldMemOperand(callee, FunctionTemplateInfo::kCallCodeOffset)); |
+ } |
__ Ldr(data, FieldMemOperand(data, CallHandlerInfo::kDataOffset)); |
} |
@@ -221,7 +227,8 @@ void PropertyHandlerCompiler::GenerateApiAccessorCall( |
__ Mov(api_function_address, ref); |
// Jump to stub. |
- CallApiAccessorStub stub(isolate, is_store, call_data_undefined); |
+ CallApiAccessorStub stub(isolate, is_store, call_data_undefined, |
+ !optimization.is_constant_call()); |
__ TailCallStub(&stub); |
} |