]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
netfilter: nf_conncount: update last_gc only when GC has been performed
authorFernando Fernandez Mancera <fmancera@suse.de>
Wed, 17 Dec 2025 14:46:40 +0000 (15:46 +0100)
committerFlorian Westphal <fw@strlen.de>
Fri, 2 Jan 2026 09:44:28 +0000 (10:44 +0100)
Currently last_gc is being updated everytime a new connection is
tracked, that means that it is updated even if a GC wasn't performed.
With a sufficiently high packet rate, it is possible to always bypass
the GC, causing the list to grow infinitely.

Update the last_gc value only when a GC has been actually performed.

Fixes: d265929930e2 ("netfilter: nf_conncount: reduce unnecessary GC")
Signed-off-by: Fernando Fernandez Mancera <fmancera@suse.de>
Signed-off-by: Florian Westphal <fw@strlen.de>
net/netfilter/nf_conncount.c

index 3654f1e8976c915aec5a6ce4a0948cf12fd5a641..8487808c87614f56c1377af4e148e12b2dbf1a2f 100644 (file)
@@ -229,6 +229,7 @@ static int __nf_conncount_add(struct net *net,
 
                nf_ct_put(found_ct);
        }
+       list->last_gc = (u32)jiffies;
 
 add_new_node:
        if (WARN_ON_ONCE(list->count > INT_MAX)) {
@@ -248,7 +249,6 @@ add_new_node:
        conn->jiffies32 = (u32)jiffies;
        list_add_tail(&conn->node, &list->head);
        list->count++;
-       list->last_gc = (u32)jiffies;
 
 out_put:
        if (refcounted)