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?
> list_del(&cl->sibling);
>
> if (cl->prio_activity)
> @@ -1333,8 +1335,10 @@ static int htb_delete(struct Qdisc *sch,
> sch_tree_lock(sch);
>
> /* delete from hash and active; remainder in destroy_class */
> - if (!hlist_unhashed(&cl->hlist))
> + if (!hlist_unhashed(&cl->hlist)) {
> hlist_del(&cl->hlist);
> + INIT_HLIST_NODE(&cl->hlist);
> + }
>
> if (cl->prio_activity)
> htb_deactivate(q, cl);
--
Stephen Hemminger <[EMAIL PROTECTED]>
-
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