Commit 856b3223 authored by Konstantin Khlebnikov's avatar Konstantin Khlebnikov Committed by Kleber Sacilotto de Souza

net_sched: blackhole: tell upper qdisc about dropped packets

BugLink: https://bugs.launchpad.net/bugs/1790884

[ Upstream commit 7e85dc8c ]

When blackhole is used on top of classful qdisc like hfsc it breaks
qlen and backlog counters because packets are disappear without notice.

In HFSC non-zero qlen while all classes are inactive triggers warning:
WARNING: ... at net/sched/sch_hfsc.c:1393 hfsc_dequeue+0xba4/0xe90 [sch_hfsc]
and schedules watchdog work endlessly.

This patch return __NET_XMIT_BYPASS in addition to NET_XMIT_SUCCESS,
this flag tells upper layer: this packet is gone and isn't queued.
Signed-off-by: default avatarKonstantin Khlebnikov <khlebnikov@yandex-team.ru>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarStefan Bader <stefan.bader@canonical.com>
Signed-off-by: default avatarKleber Sacilotto de Souza <kleber.souza@canonical.com>
parent 676363d9
...@@ -20,7 +20,7 @@ ...@@ -20,7 +20,7 @@
static int blackhole_enqueue(struct sk_buff *skb, struct Qdisc *sch) static int blackhole_enqueue(struct sk_buff *skb, struct Qdisc *sch)
{ {
qdisc_drop(skb, sch); qdisc_drop(skb, sch);
return NET_XMIT_SUCCESS; return NET_XMIT_SUCCESS | __NET_XMIT_BYPASS;
} }
static struct sk_buff *blackhole_dequeue(struct Qdisc *sch) static struct sk_buff *blackhole_dequeue(struct Qdisc *sch)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment