Page Menu
Home
FreeBSD
Search
Configure Global Search
Log In
Files
F108642741
D34204.diff
No One
Temporary
Actions
View File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Flag For Later
Award Token
Size
1 KB
Referenced Files
None
Subscribers
None
D34204.diff
View Options
diff --git a/sys/kern/subr_sleepqueue.c b/sys/kern/subr_sleepqueue.c
--- a/sys/kern/subr_sleepqueue.c
+++ b/sys/kern/subr_sleepqueue.c
@@ -833,7 +833,8 @@
td->td_sleepqueue = LIST_FIRST(&sq->sq_free);
LIST_REMOVE(td->td_sleepqueue, sq_hash);
- if ((td->td_flags & TDF_TIMEOUT) == 0 && td->td_sleeptimo != 0)
+ if ((td->td_flags & TDF_TIMEOUT) == 0 && td->td_sleeptimo != 0 &&
+ td->td_lock == &sc->sc_lock) {
/*
* We ignore the situation where timeout subsystem was
* unable to stop our callout. The struct thread is
@@ -843,8 +844,16 @@
* sleepq_timeout() ensure that the thread does not
* get spurious wakeups, even if the callout was reset
* or thread reused.
+ *
+ * We also cannot safely stop the callout if a scheduler
+ * lock is held since softclock_thread() forces a lock
+ * order of callout lock -> scheduler lock. The thread
+ * lock will be a scheduler lock only if the thread is
+ * preparing to go to sleep, so this is hopefully a rare
+ * scenario.
*/
callout_stop(&td->td_slpcallout);
+ }
td->td_wmesg = NULL;
td->td_wchan = NULL;
File Metadata
Details
Attached
Mime Type
text/plain
Expires
Tue, Jan 28, 1:20 AM (5 h, 36 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
16232943
Default Alt Text
D34204.diff (1 KB)
Attached To
Mode
D34204: sleepqueue: Address a lock order reversal
Attached
Detach File
Event Timeline
Log In to Comment