Index: src/ic/x64/handler-compiler-x64.cc |
diff --git a/src/ic/x64/handler-compiler-x64.cc b/src/ic/x64/handler-compiler-x64.cc |
index b83820f07e9ea45609e41e89de45bdb51f1a650d..85f0973e16a931d7f81463892ce0088cdcead9d3 100644 |
--- a/src/ic/x64/handler-compiler-x64.cc |
+++ b/src/ic/x64/handler-compiler-x64.cc |
@@ -181,9 +181,16 @@ void PropertyHandlerCompiler::GenerateApiAccessorCall( |
call_data_undefined = true; |
__ LoadRoot(data, Heap::kUndefinedValueRootIndex); |
} else { |
- __ movp(data, FieldOperand(callee, JSFunction::kSharedFunctionInfoOffset)); |
- __ movp(data, FieldOperand(data, SharedFunctionInfo::kFunctionDataOffset)); |
- __ movp(data, FieldOperand(data, FunctionTemplateInfo::kCallCodeOffset)); |
+ if (optimization.is_constant_call()) { |
+ __ movp(data, |
+ FieldOperand(callee, JSFunction::kSharedFunctionInfoOffset)); |
+ __ movp(data, |
+ FieldOperand(data, SharedFunctionInfo::kFunctionDataOffset)); |
+ __ movp(data, FieldOperand(data, FunctionTemplateInfo::kCallCodeOffset)); |
+ } else { |
+ __ movp(data, |
+ FieldOperand(callee, FunctionTemplateInfo::kCallCodeOffset)); |
+ } |
__ movp(data, FieldOperand(data, CallHandlerInfo::kDataOffset)); |
} |
@@ -200,7 +207,8 @@ void PropertyHandlerCompiler::GenerateApiAccessorCall( |
RelocInfo::EXTERNAL_REFERENCE); |
// 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); |
} |