On Tue, 7 Nov 2006 07:49:43 +0100 Jarek Poplawski <[EMAIL PROTECTED]> wrote:
> On Mon, Nov 06, 2006 at 09:44:49AM -0800, Stephen Hemminger wrote: > > On Mon, 6 Nov 2006 12:33:53 +0100 > > Jarek Poplawski <[EMAIL PROTECTED]> wrote: > > > > > After hlist_del() next and pprev pointers are not NULL > > > so hlist_unhashed() doesn't work properly. > > > > > > > > > Signed-off-by: Jarek Poplawski <[EMAIL PROTECTED]> > > > --- > > > > > > > > > diff -Nurp linux-2.6.19-rc4-git10-/net/sched/sch_htb.c > > > linux-2.6.19-rc4-git10/net/sched/sch_htb.c > > > --- linux-2.6.19-rc4-git10-/net/sched/sch_htb.c 2006-11-06 > > > 11:42:41.000000000 +0100 > > > +++ linux-2.6.19-rc4-git10/net/sched/sch_htb.c 2006-11-06 > > > 11:53:15.000000000 +0100 > > > @@ -1284,8 +1284,10 @@ static void htb_destroy_class(struct Qdi > > > struct htb_class, sibling)); > > > > > > /* note: this delete may happen twice (see htb_delete) */ > > > - if (!hlist_unhashed(&cl->hlist)) > > > + if (!hlist_unhashed(&cl->hlist)) { > > > hlist_del(&cl->hlist); > > > + INIT_HLIST_NODE(&cl->hlist); > > > + } > > > > why not use hlist_del_init? Your patch duplicated the code in hlist_del_init(). Why not do: --- a/net/sched/sch_htb.c 2006-11-07 09:48:22.000000000 -0800 +++ b/net/sched/sch_htb.c 2006-11-07 09:49:01.000000000 -0800 @@ -1284,8 +1284,7 @@ struct htb_class, sibling)); /* note: this delete may happen twice (see htb_delete) */ - if (!hlist_unhashed(&cl->hlist)) - hlist_del(&cl->hlist); + hlist_del_init(&cl->hlist); list_del(&cl->sibling); if (cl->prio_activity) @@ -1333,8 +1332,7 @@ sch_tree_lock(sch); /* delete from hash and active; remainder in destroy_class */ - if (!hlist_unhashed(&cl->hlist)) - hlist_del(&cl->hlist); + hlist_del_init(&cl->hlist); if (cl->prio_activity) htb_deactivate(q, cl); - To unsubscribe from this list: send the line "unsubscribe netdev" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html