8286808: Loom: Simplify generate_cont_thaw by passing thaw_kind directly

Reviewed-by: rpressler, rehn
This commit is contained in:
Aleksey Shipilev 2022-05-17 10:50:45 +00:00
parent 6a7709320d
commit b434b1f233
5 changed files with 29 additions and 33 deletions

View File

@ -6552,8 +6552,9 @@ class StubGenerator: public StubCodeGenerator {
return stub; return stub;
} }
address generate_cont_thaw(bool return_barrier, bool exception) { address generate_cont_thaw(Continuation::thaw_kind kind) {
assert(return_barrier || !exception, "must be"); bool return_barrier = Continuation::is_thaw_return_barrier(kind);
bool return_barrier_exception = Continuation::is_thaw_return_barrier_exception(kind);
address start = __ pc(); address start = __ pc();
@ -6569,7 +6570,7 @@ class StubGenerator: public StubCodeGenerator {
__ stp(rscratch1, r0, Address(__ pre(sp, -2 * wordSize))); __ stp(rscratch1, r0, Address(__ pre(sp, -2 * wordSize)));
} }
__ movw(c_rarg1, (return_barrier ? 1 : 0) + (exception ? 1 : 0)); __ movw(c_rarg1, (return_barrier ? 1 : 0));
__ call_VM_leaf(CAST_FROM_FN_PTR(address, Continuation::prepare_thaw), rthread, c_rarg1); __ call_VM_leaf(CAST_FROM_FN_PTR(address, Continuation::prepare_thaw), rthread, c_rarg1);
__ mov(rscratch2, r0); // r0 contains the size of the frames to thaw, 0 if overflow or no more frames __ mov(rscratch2, r0); // r0 contains the size of the frames to thaw, 0 if overflow or no more frames
@ -6600,9 +6601,7 @@ class StubGenerator: public StubCodeGenerator {
} }
// If we want, we can templatize thaw by kind, and have three different entries // If we want, we can templatize thaw by kind, and have three different entries
if (exception) __ movw(c_rarg1, (uint32_t)Continuation::thaw_exception); __ movw(c_rarg1, (uint32_t)kind);
else if (return_barrier) __ movw(c_rarg1, (uint32_t)Continuation::thaw_return_barrier);
else __ movw(c_rarg1, (uint32_t)Continuation::thaw_top);
__ call_VM_leaf(Continuation::thaw_entry(), rthread, c_rarg1); __ call_VM_leaf(Continuation::thaw_entry(), rthread, c_rarg1);
__ mov(rscratch2, r0); // r0 is the sp of the yielding frame __ mov(rscratch2, r0); // r0 is the sp of the yielding frame
@ -6619,7 +6618,7 @@ class StubGenerator: public StubCodeGenerator {
__ sub(sp, rscratch2, 2*wordSize); // now pointing to rfp spill __ sub(sp, rscratch2, 2*wordSize); // now pointing to rfp spill
__ mov(rfp, sp); __ mov(rfp, sp);
if (exception) { if (return_barrier_exception) {
__ ldr(c_rarg1, Address(rfp, wordSize)); // return address __ ldr(c_rarg1, Address(rfp, wordSize)); // return address
__ verify_oop(r0); __ verify_oop(r0);
__ mov(r19, r0); // save return value contaning the exception oop in callee-saved R19 __ mov(r19, r0); // save return value contaning the exception oop in callee-saved R19
@ -6652,7 +6651,7 @@ class StubGenerator: public StubCodeGenerator {
StubCodeMark mark(this, "StubRoutines", "Cont thaw"); StubCodeMark mark(this, "StubRoutines", "Cont thaw");
address start = __ pc(); address start = __ pc();
generate_cont_thaw(false, false); generate_cont_thaw(Continuation::thaw_top);
return start; return start;
} }
@ -6663,7 +6662,7 @@ class StubGenerator: public StubCodeGenerator {
StubCodeMark mark(this, "StubRoutines", "cont return barrier"); StubCodeMark mark(this, "StubRoutines", "cont return barrier");
address start = __ pc(); address start = __ pc();
generate_cont_thaw(true, false); generate_cont_thaw(Continuation::thaw_return_barrier);
return start; return start;
} }
@ -6674,7 +6673,7 @@ class StubGenerator: public StubCodeGenerator {
StubCodeMark mark(this, "StubRoutines", "cont return barrier exception handler"); StubCodeMark mark(this, "StubRoutines", "cont return barrier exception handler");
address start = __ pc(); address start = __ pc();
generate_cont_thaw(true, true); generate_cont_thaw(Continuation::thaw_return_barrier_exception);
return start; return start;
} }

View File

@ -4507,12 +4507,6 @@ class StubGenerator: public StubCodeGenerator {
return nullptr; return nullptr;
} }
address generate_cont_thaw(bool return_barrier, bool exception) {
if (!Continuations::enabled()) return nullptr;
Unimplemented();
return nullptr;
}
address generate_cont_thaw() { address generate_cont_thaw() {
if (!Continuations::enabled()) return nullptr; if (!Continuations::enabled()) return nullptr;
Unimplemented(); Unimplemented();

View File

@ -3872,12 +3872,6 @@ class StubGenerator: public StubCodeGenerator {
return nullptr; return nullptr;
} }
address generate_cont_thaw(bool return_barrier, bool exception) {
if (!Continuations::enabled()) return nullptr;
Unimplemented();
return nullptr;
}
address generate_cont_thaw() { address generate_cont_thaw() {
if (!Continuations::enabled()) return nullptr; if (!Continuations::enabled()) return nullptr;
Unimplemented(); Unimplemented();

View File

@ -7490,8 +7490,9 @@ address generate_avx_ghash_processBlocks() {
return stub; return stub;
} }
address generate_cont_thaw(bool return_barrier, bool exception) { address generate_cont_thaw(Continuation::thaw_kind kind) {
assert(return_barrier || !exception, "must be"); bool return_barrier = Continuation::is_thaw_return_barrier(kind);
bool return_barrier_exception = Continuation::is_thaw_return_barrier_exception(kind);
address start = __ pc(); address start = __ pc();
@ -7508,7 +7509,7 @@ address generate_avx_ghash_processBlocks() {
__ push(rax); __ push_d(xmm0); // preserve possible return value from a method returning to the return barrier __ push(rax); __ push_d(xmm0); // preserve possible return value from a method returning to the return barrier
} }
__ movl(c_rarg1, (return_barrier ? 1 : 0) + (exception ? 1 : 0)); __ movl(c_rarg1, (return_barrier ? 1 : 0));
__ call_VM_leaf(CAST_FROM_FN_PTR(address, Continuation::prepare_thaw), r15_thread, c_rarg1); __ call_VM_leaf(CAST_FROM_FN_PTR(address, Continuation::prepare_thaw), r15_thread, c_rarg1);
__ movptr(rbx, rax); // rax contains the size of the frames to thaw, 0 if overflow or no more frames __ movptr(rbx, rax); // rax contains the size of the frames to thaw, 0 if overflow or no more frames
@ -7531,9 +7532,7 @@ address generate_avx_ghash_processBlocks() {
} }
// If we want, we can templatize thaw by kind, and have three different entries // If we want, we can templatize thaw by kind, and have three different entries
if (exception) __ movl(c_rarg1, (int32_t)Continuation::thaw_exception); __ movl(c_rarg1, (int32_t) kind);
else if (return_barrier) __ movl(c_rarg1, (int32_t)Continuation::thaw_return_barrier);
else __ movl(c_rarg1, (int32_t)Continuation::thaw_top);
__ call_VM_leaf(Continuation::thaw_entry(), r15_thread, c_rarg1); __ call_VM_leaf(Continuation::thaw_entry(), r15_thread, c_rarg1);
__ movptr(rbx, rax); // rax is the sp of the yielding frame __ movptr(rbx, rax); // rax is the sp of the yielding frame
@ -7547,7 +7546,7 @@ address generate_avx_ghash_processBlocks() {
__ movptr(rsp, rbx); // we're now on the yield frame (which is in an address above us b/c rsp has been pushed down) __ movptr(rsp, rbx); // we're now on the yield frame (which is in an address above us b/c rsp has been pushed down)
__ subptr(rsp, 2*wordSize); // now pointing to rbp spill __ subptr(rsp, 2*wordSize); // now pointing to rbp spill
if (exception) { if (return_barrier_exception) {
__ movptr(c_rarg1, Address(rsp, wordSize)); // return address __ movptr(c_rarg1, Address(rsp, wordSize)); // return address
__ push(rax); // save return value contaning the exception oop __ push(rax); // save return value contaning the exception oop
__ call_VM_leaf(CAST_FROM_FN_PTR(address, SharedRuntime::exception_handler_for_return_address), r15_thread, c_rarg1); __ call_VM_leaf(CAST_FROM_FN_PTR(address, SharedRuntime::exception_handler_for_return_address), r15_thread, c_rarg1);
@ -7570,7 +7569,7 @@ address generate_avx_ghash_processBlocks() {
StubCodeMark mark(this, "StubRoutines", "Cont thaw"); StubCodeMark mark(this, "StubRoutines", "Cont thaw");
address start = __ pc(); address start = __ pc();
generate_cont_thaw(false, false); generate_cont_thaw(Continuation::thaw_top);
return start; return start;
} }
@ -7581,7 +7580,7 @@ address generate_avx_ghash_processBlocks() {
StubCodeMark mark(this, "StubRoutines", "cont return barrier"); StubCodeMark mark(this, "StubRoutines", "cont return barrier");
address start = __ pc(); address start = __ pc();
generate_cont_thaw(true, false); generate_cont_thaw(Continuation::thaw_return_barrier);
return start; return start;
} }
@ -7592,7 +7591,7 @@ address generate_avx_ghash_processBlocks() {
StubCodeMark mark(this, "StubRoutines", "cont return barrier exception handler"); StubCodeMark mark(this, "StubRoutines", "cont return barrier exception handler");
address start = __ pc(); address start = __ pc();
generate_cont_thaw(true, true); generate_cont_thaw(Continuation::thaw_return_barrier_exception);
return start; return start;
} }

View File

@ -62,9 +62,19 @@ public:
enum thaw_kind { enum thaw_kind {
thaw_top = 0, thaw_top = 0,
thaw_return_barrier = 1, thaw_return_barrier = 1,
thaw_exception = 2, thaw_return_barrier_exception = 2,
}; };
static bool is_thaw_return_barrier(thaw_kind kind) {
return kind != thaw_top;
}
static bool is_thaw_return_barrier_exception(thaw_kind kind) {
bool r = (kind == thaw_return_barrier_exception);
assert(!r || is_thaw_return_barrier(kind), "must be");
return r;
}
static void init(); static void init();
static address freeze_entry(); static address freeze_entry();