Skip to content

Commit 62d591d

Browse files
BitsByWillgregkh
authored andcommitted
net/sched: Make cake_enqueue return NET_XMIT_CN when past buffer_limit
[ Upstream commit 15de71d ] The following setup can trigger a WARNING in htb_activate due to the condition: !cl->leaf.q->q.qlen tc qdisc del dev lo root tc qdisc add dev lo root handle 1: htb default 1 tc class add dev lo parent 1: classid 1:1 \ htb rate 64bit tc qdisc add dev lo parent 1:1 handle f: \ cake memlimit 1b ping -I lo -f -c1 -s64 -W0.001 127.0.0.1 This is because the low memlimit leads to a low buffer_limit, which causes packet dropping. However, cake_enqueue still returns NET_XMIT_SUCCESS, causing htb_enqueue to call htb_activate with an empty child qdisc. We should return NET_XMIT_CN when packets are dropped from the same tin and flow. I do not believe return value of NET_XMIT_CN is necessary for packet drops in the case of ack filtering, as that is meant to optimize performance, not to signal congestion. Fixes: 046f6fd ("sched: Add Common Applications Kept Enhanced (cake) qdisc") Signed-off-by: William Liu <will@willsroot.io> Reviewed-by: Savino Dicanosa <savy@syst3mfailure.io> Acked-by: Toke Høiland-Jørgensen <toke@toke.dk> Reviewed-by: Jamal Hadi Salim <jhs@mojatatu.com> Link: https://patch.msgid.link/20250819033601.579821-1-will@willsroot.io Signed-off-by: Jakub Kicinski <kuba@kernel.org> Signed-off-by: Sasha Levin <sashal@kernel.org>
1 parent be90626 commit 62d591d

File tree

1 file changed

+12
-2
lines changed

1 file changed

+12
-2
lines changed

net/sched/sch_cake.c

Lines changed: 12 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1747,7 +1747,7 @@ static s32 cake_enqueue(struct sk_buff *skb, struct Qdisc *sch,
17471747
ktime_t now = ktime_get();
17481748
struct cake_tin_data *b;
17491749
struct cake_flow *flow;
1750-
u32 idx;
1750+
u32 idx, tin;
17511751

17521752
/* choose flow to insert into */
17531753
idx = cake_classify(sch, &b, skb, q->flow_mode, &ret);
@@ -1757,6 +1757,7 @@ static s32 cake_enqueue(struct sk_buff *skb, struct Qdisc *sch,
17571757
__qdisc_drop(skb, to_free);
17581758
return ret;
17591759
}
1760+
tin = (u32)(b - q->tins);
17601761
idx--;
17611762
flow = &b->flows[idx];
17621763

@@ -1924,13 +1925,22 @@ static s32 cake_enqueue(struct sk_buff *skb, struct Qdisc *sch,
19241925
q->buffer_max_used = q->buffer_used;
19251926

19261927
if (q->buffer_used > q->buffer_limit) {
1928+
bool same_flow = false;
19271929
u32 dropped = 0;
1930+
u32 drop_id;
19281931

19291932
while (q->buffer_used > q->buffer_limit) {
19301933
dropped++;
1931-
cake_drop(sch, to_free);
1934+
drop_id = cake_drop(sch, to_free);
1935+
1936+
if ((drop_id >> 16) == tin &&
1937+
(drop_id & 0xFFFF) == idx)
1938+
same_flow = true;
19321939
}
19331940
b->drop_overlimit += dropped;
1941+
1942+
if (same_flow)
1943+
return NET_XMIT_CN;
19341944
}
19351945
return NET_XMIT_SUCCESS;
19361946
}

0 commit comments

Comments
 (0)