From owner-freebsd-usb@FreeBSD.ORG Thu Aug 21 07:04:17 2008 Return-Path: Delivered-To: freebsd-usb@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 369C11065698; Thu, 21 Aug 2008 07:04:17 +0000 (UTC) (envelope-from hselasky@c2i.net) Received: from swip.net (mailfe07.swip.net [212.247.154.193]) by mx1.freebsd.org (Postfix) with ESMTP id F28F08FC08; Thu, 21 Aug 2008 07:04:15 +0000 (UTC) (envelope-from hselasky@c2i.net) X-Cloudmark-Score: 0.000000 [] X-Cloudmark-Analysis: v=1.0 c=1 a=H3poPDSvFasA:10 a=fj6dw-CIB2gA:10 a=6MIg2jpqvhTpo/gR8GzG7Q==:17 a=SKRtMQ3HR3uuMNcyNf4A:9 a=ukNOB5yV7h3YP6qRMhUA:7 a=wxQuF6-wC1qPsGBkqf3EvnflXeQA:4 a=LY0hPdMaydYA:10 Received: from [62.113.133.243] (account mc467741@c2i.net [62.113.133.243] verified) by mailfe07.swip.net (CommuniGate Pro SMTP 5.2.6) with ESMTPA id 1045643101; Thu, 21 Aug 2008 09:04:14 +0200 From: Hans Petter Selasky To: Alfred Perlstein Date: Thu, 21 Aug 2008 09:05:57 +0200 User-Agent: KMail/1.9.7 References: <20080818205914.GJ16977@elvis.mu.org> <48AC54B8.4040406@FreeBSD.org> <20080820211644.GD16977@elvis.mu.org> In-Reply-To: <20080820211644.GD16977@elvis.mu.org> MIME-Version: 1.0 Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: 7bit Content-Disposition: inline Message-Id: <200808210905.59150.hselasky@c2i.net> Cc: freebsd-multimedia@freebsd.org, freebsd-usb@freebsd.org Subject: Re: usb4bsd patch review [was Re: ...] X-BeenThere: freebsd-usb@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: FreeBSD support for USB List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 21 Aug 2008 07:04:17 -0000 On Wednesday 20 August 2008, Alfred Perlstein wrote: > [[ Reply to Hans at end of this ]] > [[ Reply to Kris inline ]] > Hi, I've CC'ed multimedia. We have the following diff to mixer.c. Can anyone tell if it will have any negative consequences: --- sys/dev/sound/pcm/mixer.c August 2008 +++ sys.new/dev/sound/pcm/mixer.c August 2008 @@ -589,7 +589,7 @@ KASSERT(m->type == MIXER_TYPE_SECONDARY, ("%s(): illegal mixer type=%d", __func__, m->type)); - snd_mtxlock(m->lock); + /* mixer uninit can sleep --hps */ MIXER_UNINIT(m); @@ -704,14 +704,24 @@ return EBUSY; } + /* destroy dev can sleep --hps */ + + snd_mtxunlock(m->lock); + pdev->si_drv1 = NULL; destroy_dev(pdev); + snd_mtxlock(m->lock); + for (i = 0; i < SOUND_MIXER_NRDEVICES; i++) mixer_set(m, i, 0); mixer_setrecsrc(m, SOUND_MASK_MIC); + snd_mtxunlock(m->lock); + + /* mixer uninit can sleep --hps */ + MIXER_UNINIT(m); snd_mtxfree(m->lock); @@ -1280,3 +1290,16 @@ return (EINVAL); } > > >>P.S. There were a number of questions you didn't answer, can I assume > > >>those will follow later? > > > > > >Could you please repeat the questions you did not get an answer to? > > > > I've repeated some of them already. e.g. in this mail you still didn't > > answer the "is it safe to drop the locks" question which was asked > > twice. Rather than me repeating them yet again, I'd suggest you go back > > and take another close read over my emails and your responses, and reply > > to the questions that are still not resolved. > > Hans, let's just leave sound the way it is. I will remove that > part of the patch. It might be better to leave a bad locking > in that generates a warning rather than obscure the locking issue > by removing the warning without fully understanding the issues. USB audio is the only sound device I know about that is regularly plugged in and out, which is causing this code path to be executed, unless you load unload a sound module, which I think is very rarely done. The lock in question has never before been exposed to the underlying layers, so the funtions that are called should not have any knowledge about it and consequently not depend on it either. Alfred: Just make sure that everything builds. We can fix up these issues afterwards. If USB sound support is broken it is not that critical. ---HPS