Skip to content

Commit

Permalink
Merge pull request #20802 from theresa-m/fix_17135
Browse files Browse the repository at this point in the history
Return from park immediately for non-positive time since epoch
  • Loading branch information
tajila authored Jan 3, 2025
2 parents 6b1a336 + 42ce9ec commit 6ceb6da
Showing 1 changed file with 15 additions and 11 deletions.
26 changes: 15 additions & 11 deletions runtime/vm/threadpark.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -45,20 +45,24 @@ threadParkImpl(J9VMThread *vmThread, BOOLEAN timeoutIsEpochRelative, I_64 timeou
J9JavaVM *vm = vmThread->javaVM;

/* Trc_JCL_park_Entry(vmThread, timeoutIsEpochRelative, timeout); */
if ((0 != timeout) || (timeoutIsEpochRelative)) {
if ((0 != timeout) || timeoutIsEpochRelative) {
if (timeoutIsEpochRelative) {
/* Currently, the omrthread layer provides no direct support for absolute timeouts.
* Simulate the timeout by calculating the delta from the current time.
*/
PORT_ACCESS_FROM_VMC(vmThread);
I_64 timeNow = j9time_current_time_millis();
if (timeout <= 0) {
rc = J9THREAD_TIMED_OUT;
} else {
/* Currently, the omrthread layer provides no direct support for absolute timeouts.
* Simulate the timeout by calculating the delta from the current time.
*/
PORT_ACCESS_FROM_VMC(vmThread);
I_64 timeNow = j9time_current_time_millis();

millis = timeout - timeNow;
nanos = 0;
millis = timeout - timeNow;
nanos = 0;

if (millis <= 0) {
rc = J9THREAD_TIMED_OUT;
/*Trc_JCL_park_timeIsInPast(vmThread, timeNow);*/
if (millis <= 0) {
rc = J9THREAD_TIMED_OUT;
/* Trc_JCL_park_timeIsInPast(vmThread, timeNow); */
}
}
} else {
millis = timeout / oneMillion;
Expand Down

0 comments on commit 6ceb6da

Please sign in to comment.