| Index: src/compiler/arm64/code-generator-arm64.cc
|
| diff --git a/src/compiler/arm64/code-generator-arm64.cc b/src/compiler/arm64/code-generator-arm64.cc
|
| index 762b57a6bc2a8778bdd4f0a3b368e155e1a92953..c0f22b70636ba0c54b8dff29de08af5394040485 100644
|
| --- a/src/compiler/arm64/code-generator-arm64.cc
|
| +++ b/src/compiler/arm64/code-generator-arm64.cc
|
| @@ -1126,7 +1126,21 @@ void CodeGenerator::AssembleMove(InstructionOperand* source,
|
| Register dst = destination->IsRegister() ? g.ToRegister(destination)
|
| : scope.AcquireX();
|
| if (src.type() == Constant::kHeapObject) {
|
| - __ LoadObject(dst, src.ToHeapObject());
|
| + Handle<HeapObject> src_object = src.ToHeapObject();
|
| + if (info()->IsOptimizing() &&
|
| + src_object.is_identical_to(info()->context())) {
|
| + // Loading the context from the frame is way cheaper than
|
| + // materializing the actual context heap object address.
|
| + __ Ldr(dst, MemOperand(fp, StandardFrameConstants::kContextOffset));
|
| + } else if (info()->IsOptimizing() &&
|
| + src_object.is_identical_to(info()->closure())) {
|
| + // Loading the JSFunction from the frame is way cheaper than
|
| + // materializing the actual JSFunction heap object address.
|
| + __ Ldr(dst,
|
| + MemOperand(fp, JavaScriptFrameConstants::kFunctionOffset));
|
| + } else {
|
| + __ LoadObject(dst, src_object);
|
| + }
|
| } else {
|
| __ Mov(dst, g.ToImmediate(source));
|
| }
|
|
|