Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 37314363 authored by Eric Dumazet's avatar Eric Dumazet Committed by David S. Miller
Browse files

pkt_sched: move the sanity test in qdisc_list_add()



The WARN_ON(root == &noop_qdisc)) added in qdisc_list_add()
can trigger in normal conditions when devices are not up.
It should be done only right before the list_add_tail() call.

Fixes: e57a784d ("pkt_sched: set root qdisc before change() in attach_default_qdiscs()")
Reported-by: default avatarValdis Kletnieks <Valdis.Kletnieks@vt.edu>
Tested-by: default avatarMirco Tischler <mt-ml@gmx.de>
Signed-off-by: default avatarEric Dumazet <edumazet@google.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 92f092d1
Loading
Loading
Loading
Loading
+4 −3
Original line number Original line Diff line number Diff line
@@ -273,12 +273,13 @@ static struct Qdisc *qdisc_match_from_root(struct Qdisc *root, u32 handle)


void qdisc_list_add(struct Qdisc *q)
void qdisc_list_add(struct Qdisc *q)
{
{
	if ((q->parent != TC_H_ROOT) && !(q->flags & TCQ_F_INGRESS)) {
		struct Qdisc *root = qdisc_dev(q)->qdisc;
		struct Qdisc *root = qdisc_dev(q)->qdisc;


		WARN_ON_ONCE(root == &noop_qdisc);
		WARN_ON_ONCE(root == &noop_qdisc);
	if ((q->parent != TC_H_ROOT) && !(q->flags & TCQ_F_INGRESS))
		list_add_tail(&q->list, &root->list);
		list_add_tail(&q->list, &root->list);
	}
	}
}
EXPORT_SYMBOL(qdisc_list_add);
EXPORT_SYMBOL(qdisc_list_add);


void qdisc_list_del(struct Qdisc *q)
void qdisc_list_del(struct Qdisc *q)