From owner-cvs-src@FreeBSD.ORG Tue Feb 20 17:48:39 2007 Return-Path: X-Original-To: cvs-src@FreeBSD.org Delivered-To: cvs-src@FreeBSD.org Received: from mx1.freebsd.org (mx1.freebsd.org [69.147.83.52]) by hub.freebsd.org (Postfix) with ESMTP id 9C83016A41B; Tue, 20 Feb 2007 17:48:39 +0000 (UTC) (envelope-from sam@errno.com) Received: from ebb.errno.com (ebb.errno.com [69.12.149.25]) by mx1.freebsd.org (Postfix) with ESMTP id 5280B13C478; Tue, 20 Feb 2007 17:48:39 +0000 (UTC) (envelope-from sam@errno.com) Received: from [10.0.0.178] ([10.0.0.178]) (authenticated bits=0) by ebb.errno.com (8.13.6/8.12.6) with ESMTP id l1KHmcx5051937 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-SHA bits=256 verify=NO); Tue, 20 Feb 2007 09:48:38 -0800 (PST) (envelope-from sam@errno.com) Message-ID: <45DB3476.1050300@errno.com> Date: Tue, 20 Feb 2007 09:48:38 -0800 From: Sam Leffler Organization: Errno Consulting User-Agent: Thunderbird 1.5.0.9 (Macintosh/20061207) MIME-Version: 1.0 To: Luigi Rizzo References: <200702201545.l1KFjxF8052100@repoman.freebsd.org> <45DB2A80.1060404@errno.com> <20070220094131.A76388@xorpc.icir.org> In-Reply-To: <20070220094131.A76388@xorpc.icir.org> X-Enigmail-Version: 0.94.2.0 Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 7bit Cc: cvs-src@FreeBSD.org, Luigi Rizzo , src-committers@FreeBSD.org, cvs-all@FreeBSD.org Subject: Re: cvs commit: src/sys/dev/iwi if_iwi.c if_iwivar.h X-BeenThere: cvs-src@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: CVS commit messages for the src tree List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 20 Feb 2007 17:48:39 -0000 Luigi Rizzo wrote: > On Tue, Feb 20, 2007 at 09:06:08AM -0800, Sam Leffler wrote: >> Luigi Rizzo wrote: >> >>> + add debugging code IWI_LOCK_ASSERT() to detect missing locks. >>> These only do a printf, and should go away once we figure out why >>> the driver sometimes freezes the system due to a (yet unidentified) >>> race condition. >> LOCK_ASSERT should do a mtx_assert and not printf. If you want to >> diverge from existing convention in all other drivers please use a >> different name; e.g. IWI_LOCK_CHECK. > > done, thanks for pointing it out. > >>> + add a device_printf() in iwi_ioctl() in certain conditions >>> (see comment in the code). This helps preventing the race condition >>> mentioned above, and makes the system survive. This printf will >>> also go away once fixing this bug is completed. >> Please don't commit debug stuff like this; we've discussed this > > Also replaced with better code to address the problem. Thank you for both. > >> privately. This driver has been in use for many months w/o complaints >> of the sort you are seeing. > > The fact that I am the only one seeing (or reporting) the problem > does not mean that there is no bug (or i wouldn't spend so much > time trying to fix it :). I'm not arguing this; I just don't like to see changes back-merged w/o a chance to settle. I've used this driver for a lot and not hit the same issue you have. Clearly fixing the cause of the lockup is important but it's also important to get to the root cause which appears to be elsewhere and likely related to an unstable signal quality. I recall in your original comparison of HEAD against RELENG_6 you found some other changes that hadn't been backported related to setting the receive sensitivity and bluetooth coexistence. You would do well to look at the latest linux code (at sourceforge which leads code going into the kernel). The handling of bluetooth coexistence in particular has gone back and forth. I assume you are operating in 2.4G and not 5G? Sam