[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <20080813.035628.169565636.davem@davemloft.net>
Date: Wed, 13 Aug 2008 03:56:28 -0700 (PDT)
From: David Miller <davem@...emloft.net>
To: vegard.nossum@...il.com
Cc: adobriyan@...il.com, netdev@...r.kernel.org,
linux-kernel@...r.kernel.org, jgarzik@...ox.com
Subject: Re: [RFC][PATCH] netconsole: avoid deadlock on printk from driver
code
From: "Vegard Nossum" <vegard.nossum@...il.com>
Date: Wed, 13 Aug 2008 12:44:46 +0200
> There must also be no BUG()s, WARN()s, other debugging facilities
> (spinlock debugging, lockdep, irqtrace, etc.) triggering which may
> call printk() inside the protected section. Can we really ensure this?
> For all drivers supporting netconsole?
For all drivers supporting netconsole? Well yes, there will be some
bugs somewhere in some driver wrt. netconsole. But that's life
and why we will constantly have something to fix in the kernel isn't
it?
But one thing is for sure, your deliriously dirty ->busy thing is
emphatically not the answer.
BTW, it seems the main reason this driver is susceptible to this
problem is that it doesn't handle link status events in it's
NAPI poll handler. If it did that, you would have never seen
this deadlock.
The netpoll layer prevents recursion into the NAPI ->poll() handler.
Most drivers manage link state either in their NAPI ->poll() handler
or a periodic timer that samples the link state. Both schemes
avoid this very issue.
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists