%PDF- <> %âãÏÓ endobj 2 0 obj <> endobj 3 0 obj <>/ExtGState<>/ProcSet[/PDF/Text/ImageB/ImageC/ImageI] >>/Annots[ 28 0 R 29 0 R] /MediaBox[ 0 0 595.5 842.25] /Contents 4 0 R/Group<>/Tabs/S>> endobj ºaâÚÎΞ-ÌE1ÍØÄ÷{òò2ÿ ÛÖ^ÔÀá TÎ{¦?§®¥kuµùÕ5sLOšuY>endobj 2 0 obj<>endobj 2 0 obj<>endobj 2 0 obj<>endobj 2 0 obj<> endobj 2 0 obj<>endobj 2 0 obj<>es 3 0 R>> endobj 2 0 obj<> ox[ 0.000000 0.000000 609.600000 935.600000]/Fi endobj 3 0 obj<> endobj 7 1 obj<>/ProcSet[/PDF/Text/ImageB/ImageC/ImageI]>>/Subtype/Form>> stream
// Copyright 2021 the V8 project authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef V8_BASELINE_RISCV64_BASELINE_COMPILER_RISCV64_INL_H_ #define V8_BASELINE_RISCV64_BASELINE_COMPILER_RISCV64_INL_H_ #include "src/baseline/baseline-compiler.h" namespace v8 { namespace internal { namespace baseline { #define __ basm_. void BaselineCompiler::Prologue() { ASM_CODE_COMMENT(&masm_); // Enter the frame here, since CallBuiltin will override lr. __ masm()->EnterFrame(StackFrame::BASELINE); DCHECK_EQ(kJSFunctionRegister, kJavaScriptCallTargetRegister); int max_frame_size = bytecode_->frame_size() + max_call_args_ * kSystemPointerSize; CallBuiltin<Builtin::kBaselineOutOfLinePrologue>( kContextRegister, kJSFunctionRegister, kJavaScriptCallArgCountRegister, max_frame_size, kJavaScriptCallNewTargetRegister, bytecode_); PrologueFillFrame(); } void BaselineCompiler::PrologueFillFrame() { ASM_CODE_COMMENT(&masm_); // Inlined register frame fill interpreter::Register new_target_or_generator_register = bytecode_->incoming_new_target_or_generator_register(); __ LoadRoot(kInterpreterAccumulatorRegister, RootIndex::kUndefinedValue); int register_count = bytecode_->register_count(); // Magic value const int kLoopUnrollSize = 8; const int new_target_index = new_target_or_generator_register.index(); const bool has_new_target = new_target_index != kMaxInt; if (has_new_target) { DCHECK_LE(new_target_index, register_count); __ masm()->Add64(sp, sp, Operand(-(kPointerSize * new_target_index))); for (int i = 0; i < new_target_index; i++) { __ masm()->Sd(kInterpreterAccumulatorRegister, MemOperand(sp, i * 8)); } // Push new_target_or_generator. __ Push(kJavaScriptCallNewTargetRegister); register_count -= new_target_index + 1; } if (register_count < 2 * kLoopUnrollSize) { // If the frame is small enough, just unroll the frame fill completely. __ masm()->Add64(sp, sp, Operand(-(kPointerSize * register_count))); for (int i = 0; i < register_count; ++i) { __ masm()->Sd(kInterpreterAccumulatorRegister, MemOperand(sp, i * 8)); } } else { __ masm()->Add64(sp, sp, Operand(-(kPointerSize * register_count))); for (int i = 0; i < register_count; ++i) { __ masm()->Sd(kInterpreterAccumulatorRegister, MemOperand(sp, i * 8)); } } } void BaselineCompiler::VerifyFrameSize() { ASM_CODE_COMMENT(&masm_); __ masm()->Add64(kScratchReg, sp, Operand(InterpreterFrameConstants::kFixedFrameSizeFromFp + bytecode_->frame_size())); __ masm()->Assert(eq, AbortReason::kUnexpectedStackPointer, kScratchReg, Operand(fp)); } #undef __ } // namespace baseline } // namespace internal } // namespace v8 #endif // V8_BASELINE_RISCV64_BASELINE_COMPILER_RISCV64_INL_H_