From 726340443a552cc1998d44d634da19482a5a63cb Mon Sep 17 00:00:00 2001 From: Derek Bruening Date: Fri, 30 Aug 2024 18:32:13 -0400 Subject: [PATCH 1/2] i#6959 all-unsched: Revert only-unscheduled fix Reverts a fix for a bug in the scheduler where it let a thread going unscheduled continue running if there are no other non-running-now scheduleable inputs. This triggered too-frequent all-unscheduled cases and the current timeout for those is too high, causing tail delays. We'll re-instate the fix once we add an early exit feature for that scenario. Issue: #6959 --- clients/drcachesim/scheduler/scheduler.cpp | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/clients/drcachesim/scheduler/scheduler.cpp b/clients/drcachesim/scheduler/scheduler.cpp index 57fa7785970..faeb91ac13a 100644 --- a/clients/drcachesim/scheduler/scheduler.cpp +++ b/clients/drcachesim/scheduler/scheduler.cpp @@ -2967,7 +2967,13 @@ scheduler_tmpl_t::pick_next_input(output_ordinal_t outpu return eof_or_idle(output, need_lock, prev_index); auto lock = std::unique_lock(*inputs_[prev_index].lock); // If we can't go back to the current input, we're EOF or idle. - if (inputs_[prev_index].at_eof || inputs_[prev_index].unscheduled) { + // TODO i#6959: We should go the EOF/idle route if + // inputs_[prev_index].unscheduled as otherwise we're ignoring its + // uncheduled transition: although if there are no other threads at + // all (not just an empty queue) this turns into the eof_or_idle() + // all-unscheduled scenario. Once we have some kind of early exit + // option we'll add the unscheduled check here. + if (inputs_[prev_index].at_eof) { lock.unlock(); return eof_or_idle(output, need_lock, prev_index); } else From c7c35bc01e5a92a854d2a0877fc0a455cc259042 Mon Sep 17 00:00:00 2001 From: Derek Bruening Date: Fri, 30 Aug 2024 19:19:08 -0400 Subject: [PATCH 2/2] Fix typo --- clients/drcachesim/scheduler/scheduler.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/clients/drcachesim/scheduler/scheduler.cpp b/clients/drcachesim/scheduler/scheduler.cpp index faeb91ac13a..cce7f596396 100644 --- a/clients/drcachesim/scheduler/scheduler.cpp +++ b/clients/drcachesim/scheduler/scheduler.cpp @@ -2969,7 +2969,7 @@ scheduler_tmpl_t::pick_next_input(output_ordinal_t outpu // If we can't go back to the current input, we're EOF or idle. // TODO i#6959: We should go the EOF/idle route if // inputs_[prev_index].unscheduled as otherwise we're ignoring its - // uncheduled transition: although if there are no other threads at + // unscheduled transition: although if there are no other threads at // all (not just an empty queue) this turns into the eof_or_idle() // all-unscheduled scenario. Once we have some kind of early exit // option we'll add the unscheduled check here.