Commit e6bbe967 authored by Ian Lance Taylor's avatar Ian Lance Taylor

runtime: don't skip timer when adjustTimers sees a modified timer

When adjustTimers sees a timerModifiedEarlier or timerModifiedLater,
it removes it from the heap, leaving a new timer at that position
in the heap. We were accidentally skipping that new timer in our loop.
In some unlikely cases this could cause adjustTimers to look at more
timers than necessary.

Change-Id: Ic71e54c175ab7d86a7fa46f1497aca71ed1c43cc
Reviewed-on: https://go-review.googlesource.com/c/go/+/214338
Run-TryBot: Ian Lance Taylor <iant@golang.org>
Reviewed-by: default avatarMichael Knyszek <mknyszek@google.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
parent 8b774103
...@@ -669,6 +669,8 @@ func adjusttimers(pp *p) { ...@@ -669,6 +669,8 @@ func adjusttimers(pp *p) {
return return
} }
} }
// Look at this heap position again.
i--
} }
case timerNoStatus, timerRunning, timerRemoving, timerRemoved, timerMoving: case timerNoStatus, timerRunning, timerRemoving, timerRemoved, timerMoving:
badTimer() badTimer()
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment