diff options
author | Philip Guenther <guenther@cvs.openbsd.org> | 2014-01-23 00:33:37 +0000 |
---|---|---|
committer | Philip Guenther <guenther@cvs.openbsd.org> | 2014-01-23 00:33:37 +0000 |
commit | edd93c1fbe6ce5e74fadbc9ae486dab01c0c9943 (patch) | |
tree | f7f10f3ccb071fdb3fde75d8ab9c5da063f81a68 | |
parent | 74c10b6e84a0aeb023610068b5a490e4c4fb830f (diff) |
Waiting on a condition without a lock is an error: you need *some* lock
to guarantee there isn't a window in which you can lose a wakeup. The
exception for tsleep() is when it's just being used to sleep for a period
of time, so permit that too.
ok jsing@ deraadt@
-rw-r--r-- | sys/kern/kern_synch.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/sys/kern/kern_synch.c b/sys/kern/kern_synch.c index c480e46f80f..e268d107e44 100644 --- a/sys/kern/kern_synch.c +++ b/sys/kern/kern_synch.c @@ -1,4 +1,4 @@ -/* $OpenBSD: kern_synch.c,v 1.112 2013/12/24 01:11:04 dlg Exp $ */ +/* $OpenBSD: kern_synch.c,v 1.113 2014/01/23 00:33:36 guenther Exp $ */ /* $NetBSD: kern_synch.c,v 1.37 1996/04/22 01:38:37 christos Exp $ */ /* @@ -109,6 +109,10 @@ tsleep(const volatile void *ident, int priority, const char *wmesg, int timo) KASSERT((priority & ~(PRIMASK | PCATCH)) == 0); +#ifdef MULTIPROCESSOR + KASSERT(timo || __mp_lock_held(&kernel_lock)); +#endif + if (cold || panicstr) { int s; /* |