// Copyright (c) 2021, the Dart project authors. Please see the AUTHORS file // for details. All rights reserved. Use of this source code is governed by a // BSD-style license that can be found in the LICENSE file. #include "vm/globals.h" #if defined(TARGET_ARCH_RISCV32) || defined(TARGET_ARCH_RISCV64) #include "vm/compiler/assembler/assembler.h" #include "vm/cpu.h" #include "vm/instructions.h" #include "vm/stub_code.h" #include "vm/unit_test.h" namespace dart { #define __ assembler-> ASSEMBLER_TEST_GENERATE(Call, assembler) { // Code is generated, but not executed. Just parsed with CallPattern __ set_constant_pool_allowed(true); // Uninitialized pp is OK. __ JumpAndLinkPatchable(StubCode::InvokeDartCode()); __ ret(); } ASSEMBLER_TEST_RUN(Call, test) { // The return address, which must be the address of an instruction contained // in the code, points to the Ret instruction above, i.e. one instruction // before the end of the code buffer. uword end = test->payload_start() + test->code().Size(); CallPattern call(end - CInstr::kInstrSize, test->code()); EXPECT_EQ(StubCode::InvokeDartCode().ptr(), call.TargetCode()); } } // namespace dart #endif // defined TARGET_ARCH_RISCV