diff --git a/util/fibers/proactor_base.cc b/util/fibers/proactor_base.cc index ebdc9160..109a8e5c 100644 --- a/util/fibers/proactor_base.cc +++ b/util/fibers/proactor_base.cc @@ -157,17 +157,20 @@ bool ProactorBase::RunOnIdleTasks() { do { on_idle_arr_.pop_back(); } while (!on_idle_arr_.empty() && !on_idle_arr_.back().task); - break; + on_idle_next_ = 0; + break; // do/while loop + } + } else { // level >= 0 + curr_ts = GetClockNanos(); + + if (unsigned(level) >= kOnIdleMaxLevel) { + level = kOnIdleMaxLevel; + should_spin = true; + } else if (on_idle_next_ < + on_idle_arr_.size()) { // check if the array has not been shrunk. + uint64_t delta_ns = uint64_t(kIdleCycleMaxMicros) * 1000 / (1 << level); + on_idle.next_ts = curr_ts + delta_ns; } - } - curr_ts = GetClockNanos(); - - if (unsigned(level) >= kOnIdleMaxLevel) { - level = kOnIdleMaxLevel; - should_spin = true; - } else if (on_idle_next_ < on_idle_arr_.size()) { // check if the array has not been shrunk. - uint64_t delta_ns = uint64_t(kIdleCycleMaxMicros) * 1000 / (1 << level); - on_idle.next_ts = curr_ts + delta_ns; } }