From owner-freebsd-smp Mon Feb 4 19:10:59 2002 Delivered-To: freebsd-smp@freebsd.org Received: from mail12.speakeasy.net (mail12.speakeasy.net [216.254.0.212]) by hub.freebsd.org (Postfix) with ESMTP id BA88137B419 for ; Mon, 4 Feb 2002 19:10:46 -0800 (PST) Received: (qmail 8110 invoked from network); 5 Feb 2002 03:10:45 -0000 Received: from unknown (HELO laptop.baldwin.cx) ([65.91.164.35]) (envelope-sender ) by mail12.speakeasy.net (qmail-ldap-1.03) with SMTP for ; 5 Feb 2002 03:10:45 -0000 Message-ID: X-Mailer: XFMail 1.4.0 on FreeBSD X-Priority: 3 (Normal) Content-Type: text/plain; charset=us-ascii Content-Transfer-Encoding: 8bit MIME-Version: 1.0 In-Reply-To: <200201201952.g0KJqY086603@apollo.backplane.com> Date: Mon, 04 Feb 2002 22:10:43 -0500 (EST) From: John Baldwin To: Matthew Dillon Subject: Re: help with mutex_pool please? Cc: smp@FreeBSD.ORG, Terry Lambert , Alfred Perlstein Sender: owner-freebsd-smp@FreeBSD.ORG Precedence: bulk List-ID: List-Archive: (Web Archive) List-Help: (List Instructions) List-Subscribe: List-Unsubscribe: X-Loop: FreeBSD.org On 20-Jan-02 Matthew Dillon wrote: > >: >:* Terry Lambert [020119 20:11] wrote: >:> Alfred Perlstein wrote: >:> > >:> > I was going to convert some subsystems to use mutex pools... >:> > >:> > However if I apply this delta, a couple of seconds after boot I get >:> > a lockup, sometimes the panic message is printed "sleeping with >:> > mutex held" >:> > >:> > Any clues? >:> >:> Implied unlock on the two destroys you removed? >: >:Ah, thanks! >: >:-- >:-Alfred Perlstein [alfred@freebsd.org] > > That sounds like a misfeature, since there had better not be any > contention with another process anyway when a mutex is in the process > of being destroyed. The mutex destroy function should probably > panic when it finds the mutex held and we should fix whatever other > cases use the misfeature. I think it is an optimization from BSD/OS due to lots of common code that does this: mtx_lock(&mumbo_struct->mb_mtx); if (this_is_last_ref_and_I_need_to_die) { mtx_destory(&mumbo_struct->mb_mtx); free(mumbo_struct, M_MUMBO); } else mtx_unlock(...); The optimization is that you avoid the unlock. It might be best to actually keep these semantics and have mtx_destroy() panic if the mutex is marked contested (not a very good way of testing this, but getting sched_lock and hten reading the MTX_CONTESTED bit would catch most cases I would hope) and then set mtx_lock to some invalid value that mtx_lock_sleep() can panic on. All this would only be for the INVARIANTS case of course, and only if the mutex is locked. If you don't allow this, then it's possible for some other code to grab the mutex while you are destroying it which would lead to worse bugs I think. At least we can detect the error condition if we keep the existing semantics. > -Matt > Matthew Dillon > -- John Baldwin <>< http://www.FreeBSD.org/~jhb/ "Power Users Use the Power to Serve!" - http://www.FreeBSD.org/ To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-smp" in the body of the message