Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1763807AbYFFFT3 (ORCPT ); Fri, 6 Jun 2008 01:19:29 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1752854AbYFFFTT (ORCPT ); Fri, 6 Jun 2008 01:19:19 -0400 Received: from smtp1.linux-foundation.org ([140.211.169.13]:44975 "EHLO smtp1.linux-foundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752697AbYFFFTS (ORCPT ); Fri, 6 Jun 2008 01:19:18 -0400 Date: Thu, 5 Jun 2008 22:18:42 -0700 From: Andrew Morton To: Tobias Diedrich Cc: netdev@vger.kernel.org, linux-kernel@vger.kernel.org, Ayaz Abdulla Subject: Re: forcedeth: lockdep warning on ethtool -s Message-Id: <20080605221842.a444ec9d.akpm@linux-foundation.org> In-Reply-To: <20080601083700.GA3036@yamamaya.is-a-geek.org> References: <20080601083700.GA3036@yamamaya.is-a-geek.org> X-Mailer: Sylpheed 2.4.8 (GTK+ 2.12.5; x86_64-redhat-linux-gnu) Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3342 Lines: 82 On Sun, 1 Jun 2008 10:37:01 +0200 Tobias Diedrich wrote: > Hi, > > After enabling CONFIG_LOCKDEP and CONFIG_PROVE_LOCKING I get the > following warning when ethtool -s is first called on one of the > forcedeth ports: > > ================================= > [ INFO: inconsistent lock state ] > 2.6.26-rc4 #28 > --------------------------------- > inconsistent {in-hardirq-W} -> {hardirq-on-W} usage. > ethtool/1985 [HC0[0]:SC0[1]:HE1:SE0] takes: > (&np->lock){++..}, at: [] nv_set_settings+0xc8/0x3de [forcedeth] > {in-hardirq-W} state was registered at: > [] 0xffffffffffffffff > irq event stamp: 3606 > hardirqs last enabled at (3605): [] _spin_unlock_irqrestore+0x3f/0x68 > hardirqs last disabled at (3604): [] _spin_lock_irqsave+0x13/0x46 > softirqs last enabled at (3534): [] __do_softirq+0xbc/0xc5 > softirqs last disabled at (3606): [] _spin_lock_bh+0x11/0x41 > > other info that might help us debug this: > 2 locks held by ethtool/1985: > #0: (rtnl_mutex){--..}, at: [] rtnl_lock+0x12/0x14 > #1: (_xmit_ETHER){-+..}, at: [] nv_set_settings+0xb3/0x3de [forcedeth] > > stack backtrace: > Pid: 1985, comm: ethtool Not tainted 2.6.26-rc4 #28 > > Call Trace: > [] print_usage_bug+0x162/0x173 > [] mark_lock+0x231/0x41f > [] __lock_acquire+0x4e7/0xcac > [] ? trace_hardirqs_on+0xf1/0x115 > [] ? disable_irq_nosync+0x6f/0x7b > [] lock_acquire+0x55/0x6e > [] ? :forcedeth:nv_set_settings+0xc8/0x3de > [] _spin_lock+0x2f/0x3c > [] :forcedeth:nv_set_settings+0xc8/0x3de > [] dev_ethtool+0x186/0xea3 > [] ? mutex_lock_nested+0x243/0x275 > [] ? debug_mutex_free_waiter+0x46/0x4a > [] ? mutex_lock_nested+0x266/0x275 > [] dev_ioctl+0x4eb/0x600 > [] ? _spin_unlock_irqrestore+0x3f/0x68 > [] sock_ioctl+0x1f5/0x202 > [] vfs_ioctl+0x2a/0x77 > [] do_vfs_ioctl+0x25b/0x270 > [] ? trace_hardirqs_on_thunk+0x35/0x3a > [] sys_ioctl+0x42/0x65 > [] system_call_after_swapgs+0x7b/0x80 > > > I think this is caused by the following snippet in nv_set_settings: > > netif_carrier_off(dev); > if (netif_running(dev)) { > nv_disable_irq(dev); > netif_tx_lock_bh(dev); > spin_lock(&np->lock); > /* stop engines */ > nv_stop_rxtx(dev); > spin_unlock(&np->lock); > netif_tx_unlock_bh(dev); > } > > > Because of nv_disable_irq this is probably not really a problem > though (I guess) and replacing the spin_lock with spin_lock_irqsave > could keep interrupts disabled for a longer period of time because > of delays in nv_stop_rx and nv_stop_tx. Could you please try that and if it works, send the patch? Thanks. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/