mirror of
https://github.com/dart-lang/sdk
synced 2024-09-20 04:21:32 +00:00
e1ffe76a36
StubEntry was holding raw pointers across safepoints in several places in the compiler. Bug: https://github.com/dart-lang/sdk/issues/34934 Change-Id: Id17cb7651f4d3508915c8cb90f5cb2353df6dac0 Reviewed-on: https://dart-review.googlesource.com/c/85040 Reviewed-by: Régis Crelier <regis@google.com> Commit-Queue: Ryan Macnak <rmacnak@google.com>
37 lines
1.1 KiB
C++
37 lines
1.1 KiB
C++
// Copyright (c) 2014, 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_ARM64)
|
|
|
|
#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 accessing pp is generated, but not executed. Uninitialized pp is OK.
|
|
__ set_constant_pool_allowed(true);
|
|
__ BranchLinkPatchable(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 - Instr::kInstrSize, test->code());
|
|
EXPECT_EQ(StubCode::InvokeDartCode().raw(), call.TargetCode());
|
|
}
|
|
|
|
} // namespace dart
|
|
|
|
#endif // defined TARGET_ARCH_ARM64
|