From: Jakub Kicinski Date: Fri, 6 Dec 2024 02:02:15 +0000 (-0800) Subject: Merge branch 'net_sched-sch_sfq-reject-limit-of-1' X-Git-Tag: v6.14-rc1~162^2~276 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=1daa6591ab7d6893cbcd8d02c2dbe43af42d36de;p=thirdparty%2Fkernel%2Flinux.git Merge branch 'net_sched-sch_sfq-reject-limit-of-1' Octavian Purdila says: ==================== net_sched: sch_sfq: reject limit of 1 The implementation does not properly support limits of 1. Add an in-kernel check, in addition to existing iproute2 check, since other tools may be used for configuration. This patch set also adds a selfcheck to test that a limit of 1 is rejected. An alternative (or in addition) we could fix the implementation by setting q->tail to NULL in sfq_drop if this is the last slot we marked empty, e.g.: --- a/net/sched/sch_sfq.c +++ b/net/sched/sch_sfq.c @@ -317,8 +317,11 @@ static unsigned int sfq_drop(struct Qdisc *sch, struct sk_buff **to_free) /* It is difficult to believe, but ALL THE SLOTS HAVE LENGTH 1. */ x = q->tail->next; slot = &q->slots[x]; - q->tail->next = slot->next; q->ht[slot->hash] = SFQ_EMPTY_SLOT; + if (x == slot->next) + q->tail = NULL; /* no more active slots */ + else + q->tail->next = slot->next; goto drop; } ==================== Link: https://patch.msgid.link/20241204030520.2084663-1-tavip@google.com Signed-off-by: Jakub Kicinski --- 1daa6591ab7d6893cbcd8d02c2dbe43af42d36de