Date: Mon, 5 Mar 2007 10:13:29 +0100 From: Maxime Henrion <mux@FreeBSD.org> To: Greg Lehey <grog@FreeBSD.org> Cc: cvs-src@FreeBSD.org, src-committers@FreeBSD.org, cvs-all@FreeBSD.org Subject: Re: cvs commit: src/share/man/man9 sleep.9 Message-ID: <20070305091329.GA65356@elvis.mu.org> In-Reply-To: <200703050559.l255xnxK035158@repoman.freebsd.org> References: <200703050559.l255xnxK035158@repoman.freebsd.org>
next in thread | previous in thread | raw e-mail | index | archive | help
Greg Lehey wrote: > grog 2007-03-05 05:59:49 UTC > > FreeBSD src repository > > Modified files: > share/man/man9 sleep.9 > Log: > Another typo. > > Spotted by: ru > Another pointy hat to: grog > > Revision Changes Path > 1.58 +1 -1 src/share/man/man9/sleep.9 I've been reading the latest version of this manpage with your modifications, and still find the information you have added in it largely misleading and/or wrong. I'm particularly worried by this paragraph : Due to the way it works, the wakeup_one() function requires that only related threads sleep on a specific chan address. It is the programmer's responsibility to choose a unique chan value. The older wakeup() func- tion did not require this, though it was never good practice for threads to share a chan value. When converting from wakeup() to wakeup_one(), pay particular attention to ensure that no other threads wait on the same chan. You're making it look as if sharing the wait channel when using wakeup_one() is more of a problem than when using wakeup(). This isn't true; both usages are completely wrong. What is different is that when in the wakeup_one() case, the symptoms are likely to be more apparent and more annoying because chances are that it will lead to deadlocks pretty quickly. This does not make sharing wait channels "more" OK within the context of wakeup(). Also, this particular bit : "The older wakeup() function did not require this, [...]" looks entirely wrong. You are somehow mitigating it by saying that it was never a good practice to share wait channels afterwards, but this is still untrue. Sharing wait channels isn't just "not a good practice", it is entirely incorrect. As far as I can tell, the wakeup() function always required separate wait channels, it's just that the effect of the sharing wasn't necessarily visible, if every process/thread checks that the condition it was waiting on is indeed met when it is woken up (and that it goes back to sleep if it isn't). I think these changes should be backed out. As a side note, we really need to migrate from the msleep()/wakeup() API to using CVs. It would make those kind of confusions impossible. Cheers, Maxime
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20070305091329.GA65356>