blob: 4f7ecb10bf4b77cc1bf2a2ba89fdc9d1a3b11c00 [file] [log] [blame]
// 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