| To: | Patrick McHardy <kaber@xxxxxxxxx> |
|---|---|
| Subject: | Re: Lockup with 2.6.9-ac15 related to netconsole |
| From: | Francois Romieu <romieu@xxxxxxxxxxxxx> |
| Date: | Wed, 22 Dec 2004 13:39:41 +0100 |
| Cc: | Matt Mackall <mpm@xxxxxxxxxxx>, Mark Broadbent <markb@xxxxxxxxxxxxxx>, linux-kernel@xxxxxxxxxxxxxxx, netdev@xxxxxxxxxxx |
| In-reply-to: | <41C9525F.4070805@trash.net> |
| References: | <20041221002218.GA1487@electric-eye.fr.zoreil.com> <20041221005521.GD5974@waste.org> <52121.192.102.214.6.1103624620.squirrel@webmail.wetlettuce.com> <20041221123727.GA13606@electric-eye.fr.zoreil.com> <49295.192.102.214.6.1103635762.squirrel@webmail.wetlettuce.com> <20041221204853.GA20869@electric-eye.fr.zoreil.com> <20041221212737.GK5974@waste.org> <20041221225831.GA20910@electric-eye.fr.zoreil.com> <41C93FAB.9090708@trash.net> <41C9525F.4070805@trash.net> |
| Sender: | netdev-bounce@xxxxxxxxxxx |
| User-agent: | Mutt/1.4.1i |
Patrick McHardy <kaber@xxxxxxxxx> :
[...]
> at least the queued messages ordered. But you need to grab
> dev->queue_lock, otherwise you risk corrupting qdisc internal data.
> You should probably also deal with the noqueue-qdisc, which doesn't
> have an enqueue function. So it should look something like this:
If I am not mistaken, a failure on spin_trylock + the test on
xmit_lock_owner imply that it is safe to directly handle the
queue. It means that qdisc_run() has been interrupted on the
current cpu and the other paths seem fine as well. Counter-example
is welcome (no joke).
Of course the patch is completely ugly and violates any layering
principle one could think of. It was not submitted for inclusion :o)
> while (!spin_trylock(&np->dev->xmit_lock)) {
> if (np->dev->xmit_lock_owner == smp_processor_id()) {
> struct Qdisc *q;
>
> rcu_read_lock();
> q = rcu_dereference(dev->qdisc);
> if (q->enqueue) {
> spin_lock(&dev->queue_lock);
I'd expect it to deadlock if dev_queue_xmit -> qdisc_run is interrupted
on the current cpu and a printk is issued as dev->queue_lock will have
been taken elsewhere.
--
Ueimor
|
| Previous by Date: | Re: [patch 4/10] s390: network driver., Jeff Garzik |
|---|---|
| Next by Date: | Re: [PATCH] PKT_SCHED: Provide compat policer stats in action policer, jamal |
| Previous by Thread: | Re: Lockup with 2.6.9-ac15 related to netconsole, Patrick McHardy |
| Next by Thread: | Re: Lockup with 2.6.9-ac15 related to netconsole, jamal |
| Indexes: | [Date] [Thread] [Top] [All Lists] |