RFR: 8255452: Doing GC during JVMTI MethodExit event posting breaks return oop [v2]
Serguei Spitsyn
sspitsyn at openjdk.java.net
Tue Nov 3 17:53:54 UTC 2020
On Tue, 3 Nov 2020 13:52:24 GMT, Erik Österlund <eosterlund at openjdk.org> wrote:
>> Erik,
>>
>> Thank you for the update! It looks more elegant.
>>
>> One concern is that after the move of this fragment to the post_method_exit_inner:
>> 1614 if (state == NULL || !state->is_interp_only_mode()) {
>> 1615 // for any thread that actually wants method exit, interp_only_mode is set
>> 1616 return;
>> 1617 }
>> there is no guarantee that the current frame is interpreted below:
>> 1580 if (!exception_exit) {
>> 1581 oop oop_result;
>> 1582 BasicType type = current_frame.interpreter_frame_result(&oop_result, &value);
>> . . .
>> 1597 if (result.not_null() && !mh->is_native()) {
>> 1598 // We have to restore the oop on the stack for interpreter frames
>> 1599 *(oop*)current_frame.interpreter_frame_tos_address() = result();
>> 1600 }
>> Probably, extra checks for current_frame.is_interpreted_frame() in these fragments will be sufficient.
>
>> Erik,
>>
>> Thank you for the update! It looks more elegant.
>>
>> One concern is that after the move of this fragment to the post_method_exit_inner:
>>
>> ```
>> 1614 if (state == NULL || !state->is_interp_only_mode()) {
>> 1615 // for any thread that actually wants method exit, interp_only_mode is set
>> 1616 return;
>> 1617 }
>> ```
>>
>> there is no guarantee that the current frame is interpreted below:
>>
>> ```
>> 1580 if (!exception_exit) {
>> 1581 oop oop_result;
>> 1582 BasicType type = current_frame.interpreter_frame_result(&oop_result, &value);
>> . . .
>> 1597 if (result.not_null() && !mh->is_native()) {
>> 1598 // We have to restore the oop on the stack for interpreter frames
>> 1599 *(oop*)current_frame.interpreter_frame_tos_address() = result();
>> 1600 }
>> ```
>>
>> Probably, extra checks for current_frame.is_interpreted_frame() in these fragments will be sufficient.
>
> That makes sense. Added a check in the latest version that we are in interp only mode.
Hi Erik,
I'm not sure, if this fragment is still needed:
1620 if (state == NULL || !state->is_interp_only_mode()) {
1621 // for any thread that actually wants method exit, interp_only_mode is set
1622 return;
1623 }
Also, can it be that this condition is true:
` (state == NULL || !state->is_interp_only_mode())`
but the top frame is interpreted?
If so, then should we still safe/restore the result oop over a possible safepoint?
Thanks,
Serguei
-------------
PR: https://git.openjdk.java.net/jdk/pull/930
More information about the hotspot-dev
mailing list