8293939: Move continuation_enter_setup and friends
Reviewed-by: dlong, pchilanomate
This commit is contained in:
parent
f872467d69
commit
017e7988b1
@ -988,10 +988,71 @@ static void verify_oop_args(MacroAssembler* masm,
|
||||
}
|
||||
}
|
||||
|
||||
// defined in stubGenerator_aarch64.cpp
|
||||
OopMap* continuation_enter_setup(MacroAssembler* masm, int& stack_slots);
|
||||
void fill_continuation_entry(MacroAssembler* masm);
|
||||
void continuation_enter_cleanup(MacroAssembler* masm);
|
||||
// on exit, sp points to the ContinuationEntry
|
||||
static OopMap* continuation_enter_setup(MacroAssembler* masm, int& stack_slots) {
|
||||
assert(ContinuationEntry::size() % VMRegImpl::stack_slot_size == 0, "");
|
||||
assert(in_bytes(ContinuationEntry::cont_offset()) % VMRegImpl::stack_slot_size == 0, "");
|
||||
assert(in_bytes(ContinuationEntry::chunk_offset()) % VMRegImpl::stack_slot_size == 0, "");
|
||||
|
||||
stack_slots += (int)ContinuationEntry::size()/wordSize;
|
||||
__ sub(sp, sp, (int)ContinuationEntry::size()); // place Continuation metadata
|
||||
|
||||
OopMap* map = new OopMap(((int)ContinuationEntry::size() + wordSize)/ VMRegImpl::stack_slot_size, 0 /* arg_slots*/);
|
||||
ContinuationEntry::setup_oopmap(map);
|
||||
|
||||
__ ldr(rscratch1, Address(rthread, JavaThread::cont_entry_offset()));
|
||||
__ str(rscratch1, Address(sp, ContinuationEntry::parent_offset()));
|
||||
__ mov(rscratch1, sp); // we can't use sp as the source in str
|
||||
__ str(rscratch1, Address(rthread, JavaThread::cont_entry_offset()));
|
||||
|
||||
return map;
|
||||
}
|
||||
|
||||
// on entry c_rarg1 points to the continuation
|
||||
// sp points to ContinuationEntry
|
||||
// c_rarg3 -- isVirtualThread
|
||||
static void fill_continuation_entry(MacroAssembler* masm) {
|
||||
#ifdef ASSERT
|
||||
__ movw(rscratch1, ContinuationEntry::cookie_value());
|
||||
__ strw(rscratch1, Address(sp, ContinuationEntry::cookie_offset()));
|
||||
#endif
|
||||
|
||||
__ str (c_rarg1, Address(sp, ContinuationEntry::cont_offset()));
|
||||
__ strw(c_rarg3, Address(sp, ContinuationEntry::flags_offset()));
|
||||
__ str (zr, Address(sp, ContinuationEntry::chunk_offset()));
|
||||
__ strw(zr, Address(sp, ContinuationEntry::argsize_offset()));
|
||||
__ strw(zr, Address(sp, ContinuationEntry::pin_count_offset()));
|
||||
|
||||
__ ldr(rscratch1, Address(rthread, JavaThread::cont_fastpath_offset()));
|
||||
__ str(rscratch1, Address(sp, ContinuationEntry::parent_cont_fastpath_offset()));
|
||||
__ ldr(rscratch1, Address(rthread, JavaThread::held_monitor_count_offset()));
|
||||
__ str(rscratch1, Address(sp, ContinuationEntry::parent_held_monitor_count_offset()));
|
||||
|
||||
__ str(zr, Address(rthread, JavaThread::cont_fastpath_offset()));
|
||||
__ str(zr, Address(rthread, JavaThread::held_monitor_count_offset()));
|
||||
}
|
||||
|
||||
// on entry, sp points to the ContinuationEntry
|
||||
// on exit, rfp points to the spilled rfp in the entry frame
|
||||
static void continuation_enter_cleanup(MacroAssembler* masm) {
|
||||
#ifndef PRODUCT
|
||||
Label OK;
|
||||
__ ldr(rscratch1, Address(rthread, JavaThread::cont_entry_offset()));
|
||||
__ cmp(sp, rscratch1);
|
||||
__ br(Assembler::EQ, OK);
|
||||
__ stop("incorrect sp1");
|
||||
__ bind(OK);
|
||||
#endif
|
||||
|
||||
__ ldr(rscratch1, Address(sp, ContinuationEntry::parent_cont_fastpath_offset()));
|
||||
__ str(rscratch1, Address(rthread, JavaThread::cont_fastpath_offset()));
|
||||
__ ldr(rscratch1, Address(sp, ContinuationEntry::parent_held_monitor_count_offset()));
|
||||
__ str(rscratch1, Address(rthread, JavaThread::held_monitor_count_offset()));
|
||||
|
||||
__ ldr(rscratch2, Address(sp, ContinuationEntry::parent_offset()));
|
||||
__ str(rscratch2, Address(rthread, JavaThread::cont_entry_offset()));
|
||||
__ add(rfp, sp, (int)ContinuationEntry::size());
|
||||
}
|
||||
|
||||
// enterSpecial(Continuation c, boolean isContinue, boolean isVirtualThread)
|
||||
// On entry: c_rarg1 -- the continuation object
|
||||
|
@ -76,10 +76,6 @@
|
||||
|
||||
#define BIND(label) bind(label); BLOCK_COMMENT(#label ":")
|
||||
|
||||
OopMap* continuation_enter_setup(MacroAssembler* masm, int& stack_slots);
|
||||
void fill_continuation_entry(MacroAssembler* masm);
|
||||
void continuation_enter_cleanup(MacroAssembler* masm);
|
||||
|
||||
// Stub Code definitions
|
||||
|
||||
class StubGenerator: public StubCodeGenerator {
|
||||
@ -8034,75 +8030,3 @@ DEFAULT_ATOMIC_OP(cmpxchg, 8, _seq_cst)
|
||||
#undef DEFAULT_ATOMIC_OP
|
||||
|
||||
#endif // LINUX
|
||||
|
||||
|
||||
#undef __
|
||||
#define __ masm->
|
||||
|
||||
// on exit, sp points to the ContinuationEntry
|
||||
OopMap* continuation_enter_setup(MacroAssembler* masm, int& stack_slots) {
|
||||
assert(ContinuationEntry::size() % VMRegImpl::stack_slot_size == 0, "");
|
||||
assert(in_bytes(ContinuationEntry::cont_offset()) % VMRegImpl::stack_slot_size == 0, "");
|
||||
assert(in_bytes(ContinuationEntry::chunk_offset()) % VMRegImpl::stack_slot_size == 0, "");
|
||||
|
||||
stack_slots += (int)ContinuationEntry::size()/wordSize;
|
||||
__ sub(sp, sp, (int)ContinuationEntry::size()); // place Continuation metadata
|
||||
|
||||
OopMap* map = new OopMap(((int)ContinuationEntry::size() + wordSize)/ VMRegImpl::stack_slot_size, 0 /* arg_slots*/);
|
||||
ContinuationEntry::setup_oopmap(map);
|
||||
|
||||
__ ldr(rscratch1, Address(rthread, JavaThread::cont_entry_offset()));
|
||||
__ str(rscratch1, Address(sp, ContinuationEntry::parent_offset()));
|
||||
__ mov(rscratch1, sp); // we can't use sp as the source in str
|
||||
__ str(rscratch1, Address(rthread, JavaThread::cont_entry_offset()));
|
||||
|
||||
return map;
|
||||
}
|
||||
|
||||
// on entry c_rarg1 points to the continuation
|
||||
// sp points to ContinuationEntry
|
||||
// c_rarg3 -- isVirtualThread
|
||||
void fill_continuation_entry(MacroAssembler* masm) {
|
||||
#ifdef ASSERT
|
||||
__ movw(rscratch1, ContinuationEntry::cookie_value());
|
||||
__ strw(rscratch1, Address(sp, ContinuationEntry::cookie_offset()));
|
||||
#endif
|
||||
|
||||
__ str (c_rarg1, Address(sp, ContinuationEntry::cont_offset()));
|
||||
__ strw(c_rarg3, Address(sp, ContinuationEntry::flags_offset()));
|
||||
__ str (zr, Address(sp, ContinuationEntry::chunk_offset()));
|
||||
__ strw(zr, Address(sp, ContinuationEntry::argsize_offset()));
|
||||
__ strw(zr, Address(sp, ContinuationEntry::pin_count_offset()));
|
||||
|
||||
__ ldr(rscratch1, Address(rthread, JavaThread::cont_fastpath_offset()));
|
||||
__ str(rscratch1, Address(sp, ContinuationEntry::parent_cont_fastpath_offset()));
|
||||
__ ldr(rscratch1, Address(rthread, JavaThread::held_monitor_count_offset()));
|
||||
__ str(rscratch1, Address(sp, ContinuationEntry::parent_held_monitor_count_offset()));
|
||||
|
||||
__ str(zr, Address(rthread, JavaThread::cont_fastpath_offset()));
|
||||
__ str(zr, Address(rthread, JavaThread::held_monitor_count_offset()));
|
||||
}
|
||||
|
||||
// on entry, sp points to the ContinuationEntry
|
||||
// on exit, rfp points to the spilled rfp in the entry frame
|
||||
void continuation_enter_cleanup(MacroAssembler* masm) {
|
||||
#ifndef PRODUCT
|
||||
Label OK;
|
||||
__ ldr(rscratch1, Address(rthread, JavaThread::cont_entry_offset()));
|
||||
__ cmp(sp, rscratch1);
|
||||
__ br(Assembler::EQ, OK);
|
||||
__ stop("incorrect sp1");
|
||||
__ bind(OK);
|
||||
#endif
|
||||
|
||||
__ ldr(rscratch1, Address(sp, ContinuationEntry::parent_cont_fastpath_offset()));
|
||||
__ str(rscratch1, Address(rthread, JavaThread::cont_fastpath_offset()));
|
||||
__ ldr(rscratch1, Address(sp, ContinuationEntry::parent_held_monitor_count_offset()));
|
||||
__ str(rscratch1, Address(rthread, JavaThread::held_monitor_count_offset()));
|
||||
|
||||
__ ldr(rscratch2, Address(sp, ContinuationEntry::parent_offset()));
|
||||
__ str(rscratch2, Address(rthread, JavaThread::cont_entry_offset()));
|
||||
__ add(rfp, sp, (int)ContinuationEntry::size());
|
||||
}
|
||||
|
||||
#undef __
|
||||
|
@ -1976,10 +1976,6 @@ public:
|
||||
void generate_fill_avx3(BasicType type, Register to, Register value,
|
||||
Register count, Register rtmp, XMMRegister xtmp);
|
||||
#endif // COMPILER2_OR_JVMCI
|
||||
|
||||
OopMap* continuation_enter_setup(int& stack_slots);
|
||||
void fill_continuation_entry(Register reg_cont_obj, Register reg_flags);
|
||||
void continuation_enter_cleanup();
|
||||
#endif // _LP64
|
||||
|
||||
void vallones(XMMRegister dst, int vector_len);
|
||||
|
@ -1,122 +0,0 @@
|
||||
/*
|
||||
* Copyright (c) 2022, Oracle and/or its affiliates. All rights reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 only, as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
* version 2 for more details (a copy is included in the LICENSE file that
|
||||
* accompanied this code).
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License version
|
||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
* or visit www.oracle.com if you need additional information or have any
|
||||
* questions.
|
||||
*
|
||||
*/
|
||||
|
||||
#include "precompiled.hpp"
|
||||
#include "runtime/continuation.hpp"
|
||||
#include "runtime/continuationEntry.hpp"
|
||||
#include "runtime/javaThread.hpp"
|
||||
#include "macroAssembler_x86.hpp"
|
||||
|
||||
//---------------------------- continuation_enter_setup ---------------------------
|
||||
//
|
||||
// Arguments:
|
||||
// None.
|
||||
//
|
||||
// Results:
|
||||
// rsp: pointer to blank ContinuationEntry
|
||||
//
|
||||
// Kills:
|
||||
// rax
|
||||
//
|
||||
OopMap* MacroAssembler::continuation_enter_setup(int& stack_slots) {
|
||||
assert(ContinuationEntry::size() % VMRegImpl::stack_slot_size == 0, "");
|
||||
assert(in_bytes(ContinuationEntry::cont_offset()) % VMRegImpl::stack_slot_size == 0, "");
|
||||
assert(in_bytes(ContinuationEntry::chunk_offset()) % VMRegImpl::stack_slot_size == 0, "");
|
||||
|
||||
stack_slots += checked_cast<int>(ContinuationEntry::size()) / wordSize;
|
||||
subptr(rsp, checked_cast<int32_t>(ContinuationEntry::size()));
|
||||
|
||||
int frame_size = (checked_cast<int>(ContinuationEntry::size()) + wordSize) / VMRegImpl::stack_slot_size;
|
||||
OopMap* map = new OopMap(frame_size, 0);
|
||||
ContinuationEntry::setup_oopmap(map);
|
||||
|
||||
movptr(rax, Address(r15_thread, JavaThread::cont_entry_offset()));
|
||||
movptr(Address(rsp, ContinuationEntry::parent_offset()), rax);
|
||||
movptr(Address(r15_thread, JavaThread::cont_entry_offset()), rsp);
|
||||
|
||||
return map;
|
||||
}
|
||||
|
||||
//---------------------------- fill_continuation_entry ---------------------------
|
||||
//
|
||||
// Arguments:
|
||||
// rsp: pointer to blank Continuation entry
|
||||
// reg_cont_obj: pointer to the continuation
|
||||
// reg_flags: flags
|
||||
//
|
||||
// Results:
|
||||
// rsp: pointer to filled out ContinuationEntry
|
||||
//
|
||||
// Kills:
|
||||
// rax
|
||||
//
|
||||
void MacroAssembler::fill_continuation_entry(Register reg_cont_obj, Register reg_flags) {
|
||||
assert_different_registers(rax, reg_cont_obj, reg_flags);
|
||||
#ifdef ASSERT
|
||||
movl(Address(rsp, ContinuationEntry::cookie_offset()), ContinuationEntry::cookie_value());
|
||||
#endif
|
||||
movptr(Address(rsp, ContinuationEntry::cont_offset()), reg_cont_obj);
|
||||
movl (Address(rsp, ContinuationEntry::flags_offset()), reg_flags);
|
||||
movptr(Address(rsp, ContinuationEntry::chunk_offset()), 0);
|
||||
movl(Address(rsp, ContinuationEntry::argsize_offset()), 0);
|
||||
movl(Address(rsp, ContinuationEntry::pin_count_offset()), 0);
|
||||
|
||||
movptr(rax, Address(r15_thread, JavaThread::cont_fastpath_offset()));
|
||||
movptr(Address(rsp, ContinuationEntry::parent_cont_fastpath_offset()), rax);
|
||||
movq(rax, Address(r15_thread, JavaThread::held_monitor_count_offset()));
|
||||
movq(Address(rsp, ContinuationEntry::parent_held_monitor_count_offset()), rax);
|
||||
|
||||
movptr(Address(r15_thread, JavaThread::cont_fastpath_offset()), 0);
|
||||
movq(Address(r15_thread, JavaThread::held_monitor_count_offset()), 0);
|
||||
}
|
||||
|
||||
//---------------------------- continuation_enter_cleanup ---------------------------
|
||||
//
|
||||
// Arguments:
|
||||
// rsp: pointer to the ContinuationEntry
|
||||
//
|
||||
// Results:
|
||||
// rsp: pointer to the spilled rbp in the entry frame
|
||||
//
|
||||
// Kills:
|
||||
// rbx
|
||||
//
|
||||
void MacroAssembler::continuation_enter_cleanup() {
|
||||
#ifdef ASSERT
|
||||
Label L_good_sp;
|
||||
cmpptr(rsp, Address(r15_thread, JavaThread::cont_entry_offset()));
|
||||
jcc(Assembler::equal, L_good_sp);
|
||||
stop("Incorrect rsp at continuation_enter_cleanup");
|
||||
bind(L_good_sp);
|
||||
#endif
|
||||
|
||||
movptr(rbx, Address(rsp, ContinuationEntry::parent_cont_fastpath_offset()));
|
||||
movptr(Address(r15_thread, JavaThread::cont_fastpath_offset()), rbx);
|
||||
movq(rbx, Address(rsp, ContinuationEntry::parent_held_monitor_count_offset()));
|
||||
movq(Address(r15_thread, JavaThread::held_monitor_count_offset()), rbx);
|
||||
|
||||
movptr(rbx, Address(rsp, ContinuationEntry::parent_offset()));
|
||||
movptr(Address(r15_thread, JavaThread::cont_entry_offset()), rbx);
|
||||
addptr(rsp, checked_cast<int32_t>(ContinuationEntry::size()));
|
||||
}
|
@ -1271,6 +1271,100 @@ static void check_continuation_enter_argument(VMReg actual_vmreg,
|
||||
name, actual_vmreg->as_Register()->name(), expected_reg->name());
|
||||
}
|
||||
|
||||
|
||||
//---------------------------- continuation_enter_setup ---------------------------
|
||||
//
|
||||
// Arguments:
|
||||
// None.
|
||||
//
|
||||
// Results:
|
||||
// rsp: pointer to blank ContinuationEntry
|
||||
//
|
||||
// Kills:
|
||||
// rax
|
||||
//
|
||||
static OopMap* continuation_enter_setup(MacroAssembler* masm, int& stack_slots) {
|
||||
assert(ContinuationEntry::size() % VMRegImpl::stack_slot_size == 0, "");
|
||||
assert(in_bytes(ContinuationEntry::cont_offset()) % VMRegImpl::stack_slot_size == 0, "");
|
||||
assert(in_bytes(ContinuationEntry::chunk_offset()) % VMRegImpl::stack_slot_size == 0, "");
|
||||
|
||||
stack_slots += checked_cast<int>(ContinuationEntry::size()) / wordSize;
|
||||
__ subptr(rsp, checked_cast<int32_t>(ContinuationEntry::size()));
|
||||
|
||||
int frame_size = (checked_cast<int>(ContinuationEntry::size()) + wordSize) / VMRegImpl::stack_slot_size;
|
||||
OopMap* map = new OopMap(frame_size, 0);
|
||||
ContinuationEntry::setup_oopmap(map);
|
||||
|
||||
__ movptr(rax, Address(r15_thread, JavaThread::cont_entry_offset()));
|
||||
__ movptr(Address(rsp, ContinuationEntry::parent_offset()), rax);
|
||||
__ movptr(Address(r15_thread, JavaThread::cont_entry_offset()), rsp);
|
||||
|
||||
return map;
|
||||
}
|
||||
|
||||
//---------------------------- fill_continuation_entry ---------------------------
|
||||
//
|
||||
// Arguments:
|
||||
// rsp: pointer to blank Continuation entry
|
||||
// reg_cont_obj: pointer to the continuation
|
||||
// reg_flags: flags
|
||||
//
|
||||
// Results:
|
||||
// rsp: pointer to filled out ContinuationEntry
|
||||
//
|
||||
// Kills:
|
||||
// rax
|
||||
//
|
||||
static void fill_continuation_entry(MacroAssembler* masm, Register reg_cont_obj, Register reg_flags) {
|
||||
assert_different_registers(rax, reg_cont_obj, reg_flags);
|
||||
#ifdef ASSERT
|
||||
__ movl(Address(rsp, ContinuationEntry::cookie_offset()), ContinuationEntry::cookie_value());
|
||||
#endif
|
||||
__ movptr(Address(rsp, ContinuationEntry::cont_offset()), reg_cont_obj);
|
||||
__ movl (Address(rsp, ContinuationEntry::flags_offset()), reg_flags);
|
||||
__ movptr(Address(rsp, ContinuationEntry::chunk_offset()), 0);
|
||||
__ movl(Address(rsp, ContinuationEntry::argsize_offset()), 0);
|
||||
__ movl(Address(rsp, ContinuationEntry::pin_count_offset()), 0);
|
||||
|
||||
__ movptr(rax, Address(r15_thread, JavaThread::cont_fastpath_offset()));
|
||||
__ movptr(Address(rsp, ContinuationEntry::parent_cont_fastpath_offset()), rax);
|
||||
__ movq(rax, Address(r15_thread, JavaThread::held_monitor_count_offset()));
|
||||
__ movq(Address(rsp, ContinuationEntry::parent_held_monitor_count_offset()), rax);
|
||||
|
||||
__ movptr(Address(r15_thread, JavaThread::cont_fastpath_offset()), 0);
|
||||
__ movq(Address(r15_thread, JavaThread::held_monitor_count_offset()), 0);
|
||||
}
|
||||
|
||||
//---------------------------- continuation_enter_cleanup ---------------------------
|
||||
//
|
||||
// Arguments:
|
||||
// rsp: pointer to the ContinuationEntry
|
||||
//
|
||||
// Results:
|
||||
// rsp: pointer to the spilled rbp in the entry frame
|
||||
//
|
||||
// Kills:
|
||||
// rbx
|
||||
//
|
||||
void static continuation_enter_cleanup(MacroAssembler* masm) {
|
||||
#ifdef ASSERT
|
||||
Label L_good_sp;
|
||||
__ cmpptr(rsp, Address(r15_thread, JavaThread::cont_entry_offset()));
|
||||
__ jcc(Assembler::equal, L_good_sp);
|
||||
__ stop("Incorrect rsp at continuation_enter_cleanup");
|
||||
__ bind(L_good_sp);
|
||||
#endif
|
||||
|
||||
__ movptr(rbx, Address(rsp, ContinuationEntry::parent_cont_fastpath_offset()));
|
||||
__ movptr(Address(r15_thread, JavaThread::cont_fastpath_offset()), rbx);
|
||||
__ movq(rbx, Address(rsp, ContinuationEntry::parent_held_monitor_count_offset()));
|
||||
__ movq(Address(r15_thread, JavaThread::held_monitor_count_offset()), rbx);
|
||||
|
||||
__ movptr(rbx, Address(rsp, ContinuationEntry::parent_offset()));
|
||||
__ movptr(Address(r15_thread, JavaThread::cont_entry_offset()), rbx);
|
||||
__ addptr(rsp, checked_cast<int32_t>(ContinuationEntry::size()));
|
||||
}
|
||||
|
||||
static void gen_continuation_enter(MacroAssembler* masm,
|
||||
const VMRegPair* regs,
|
||||
int& exception_offset,
|
||||
@ -1330,13 +1424,13 @@ static void gen_continuation_enter(MacroAssembler* masm,
|
||||
__ enter();
|
||||
|
||||
stack_slots = 2; // will be adjusted in setup
|
||||
OopMap* map = __ continuation_enter_setup(stack_slots);
|
||||
OopMap* map = continuation_enter_setup(masm, stack_slots);
|
||||
// The frame is complete here, but we only record it for the compiled entry, so the frame would appear unsafe,
|
||||
// but that's okay because at the very worst we'll miss an async sample, but we're in interp_only_mode anyway.
|
||||
|
||||
__ verify_oop(reg_cont_obj);
|
||||
|
||||
__ fill_continuation_entry(reg_cont_obj, reg_is_virtual);
|
||||
fill_continuation_entry(masm, reg_cont_obj, reg_is_virtual);
|
||||
|
||||
// If continuation, call to thaw. Otherwise, resolve the call and exit.
|
||||
__ testptr(reg_is_cont, reg_is_cont);
|
||||
@ -1365,14 +1459,14 @@ static void gen_continuation_enter(MacroAssembler* masm,
|
||||
__ enter();
|
||||
|
||||
stack_slots = 2; // will be adjusted in setup
|
||||
OopMap* map = __ continuation_enter_setup(stack_slots);
|
||||
OopMap* map = continuation_enter_setup(masm, stack_slots);
|
||||
|
||||
// Frame is now completed as far as size and linkage.
|
||||
frame_complete = __ pc() - start;
|
||||
|
||||
__ verify_oop(reg_cont_obj);
|
||||
|
||||
__ fill_continuation_entry(reg_cont_obj, reg_is_virtual);
|
||||
fill_continuation_entry(masm, reg_cont_obj, reg_is_virtual);
|
||||
|
||||
// If isContinue, call to thaw. Otherwise, call Continuation.enter(Continuation c, boolean isContinue)
|
||||
__ testptr(reg_is_cont, reg_is_cont);
|
||||
@ -1415,7 +1509,7 @@ static void gen_continuation_enter(MacroAssembler* masm,
|
||||
|
||||
__ bind(L_exit);
|
||||
|
||||
__ continuation_enter_cleanup();
|
||||
continuation_enter_cleanup(masm);
|
||||
__ pop(rbp);
|
||||
__ ret(0);
|
||||
|
||||
@ -1423,7 +1517,7 @@ static void gen_continuation_enter(MacroAssembler* masm,
|
||||
|
||||
exception_offset = __ pc() - start;
|
||||
|
||||
__ continuation_enter_cleanup();
|
||||
continuation_enter_cleanup(masm);
|
||||
__ pop(rbp);
|
||||
|
||||
__ movptr(c_rarg0, r15_thread);
|
||||
@ -1487,7 +1581,7 @@ static void gen_continuation_yield(MacroAssembler* masm,
|
||||
__ jcc(Assembler::notZero, L_pinned);
|
||||
|
||||
__ movptr(rsp, Address(r15_thread, JavaThread::cont_entry_offset()));
|
||||
__ continuation_enter_cleanup();
|
||||
continuation_enter_cleanup(masm);
|
||||
__ pop(rbp);
|
||||
__ ret(0);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user