Skip to content

Commit 0aae24e

Browse files
author
Jozsef Kadlecsik
committed
netfilter: ipset: Fix hash type expire: release empty hash bucket block
When all entries are expired/all slots are empty, release the bucket. Signed-off-by: Jozsef Kadlecsik <kadlec@blackhole.kfki.hu>
1 parent e9dfdc0 commit 0aae24e

File tree

1 file changed

+9
-4
lines changed

1 file changed

+9
-4
lines changed

net/netfilter/ipset/ip_set_hash_gen.h

Lines changed: 9 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -476,7 +476,7 @@ static void
476476
mtype_expire(struct ip_set *set, struct htype *h, u8 nets_length, size_t dsize)
477477
{
478478
struct htable *t;
479-
struct hbucket *n;
479+
struct hbucket *n, *tmp;
480480
struct mtype_elem *data;
481481
u32 i, j, d;
482482
#ifdef IP_SET_HASH_WITH_NETS
@@ -511,9 +511,14 @@ mtype_expire(struct ip_set *set, struct htype *h, u8 nets_length, size_t dsize)
511511
}
512512
}
513513
if (d >= AHASH_INIT_SIZE) {
514-
struct hbucket *tmp = kzalloc(sizeof(*tmp) +
515-
(n->size - AHASH_INIT_SIZE) * dsize,
516-
GFP_ATOMIC);
514+
if (d >= n->size) {
515+
rcu_assign_pointer(hbucket(t, i), NULL);
516+
kfree_rcu(n, rcu);
517+
continue;
518+
}
519+
tmp = kzalloc(sizeof(*tmp) +
520+
(n->size - AHASH_INIT_SIZE) * dsize,
521+
GFP_ATOMIC);
517522
if (!tmp)
518523
/* Still try to delete expired elements */
519524
continue;

0 commit comments

Comments
 (0)