diff mbox series

netfilter: ipset: Add list flush to cancel_gc

Message ID 20240417135141.18288-1-keltar.gw@gmail.com
State New
Headers show
Series netfilter: ipset: Add list flush to cancel_gc | expand

Commit Message

Alexander Maltsev April 17, 2024, 1:51 p.m. UTC
Flushing list in cancel_gc drops references to other lists right away,
without waiting for RCU to destroy list. Fixes race when referenced
ipsets can't be destroyed while referring list is scheduled for destroy.

Signed-off-by: Alexander Maltsev <keltar.gw@gmail.com>
---
 kernel/net/netfilter/ipset/ip_set_list_set.c | 3 +++
 1 file changed, 3 insertions(+)

Comments

Jozsef Kadlecsik April 22, 2024, 8:32 a.m. UTC | #1
On Wed, 17 Apr 2024, Alexander Maltsev wrote:

> Flushing list in cancel_gc drops references to other lists right away,
> without waiting for RCU to destroy list. Fixes race when referenced
> ipsets can't be destroyed while referring list is scheduled for destroy.
> 
> Signed-off-by: Alexander Maltsev <keltar.gw@gmail.com>
> ---
>  kernel/net/netfilter/ipset/ip_set_list_set.c | 3 +++
>  1 file changed, 3 insertions(+)
> 
> diff --git a/kernel/net/netfilter/ipset/ip_set_list_set.c b/kernel/net/netfilter/ipset/ip_set_list_set.c
> index cc2e5b9..0d15f4f 100644
> --- a/kernel/net/netfilter/ipset/ip_set_list_set.c
> +++ b/kernel/net/netfilter/ipset/ip_set_list_set.c
> @@ -552,6 +552,9 @@ list_set_cancel_gc(struct ip_set *set)
>  
>  	if (SET_WITH_TIMEOUT(set))
>  		timer_shutdown_sync(&map->gc);
> +
> +	/* Flush list to drop references to other ipsets */
> +	list_set_flush(set);
>  }
>  
>  static const struct ip_set_type_variant set_variant = {

Looks good, Pablo please apply to the nf-next tree. Thanks!

Acked-by: Jozsef Kadlecsik <kadlec@netfilter.org>

Best regards,
Jozsef
diff mbox series

Patch

diff --git a/kernel/net/netfilter/ipset/ip_set_list_set.c b/kernel/net/netfilter/ipset/ip_set_list_set.c
index cc2e5b9..0d15f4f 100644
--- a/kernel/net/netfilter/ipset/ip_set_list_set.c
+++ b/kernel/net/netfilter/ipset/ip_set_list_set.c
@@ -552,6 +552,9 @@  list_set_cancel_gc(struct ip_set *set)
 
 	if (SET_WITH_TIMEOUT(set))
 		timer_shutdown_sync(&map->gc);
+
+	/* Flush list to drop references to other ipsets */
+	list_set_flush(set);
 }
 
 static const struct ip_set_type_variant set_variant = {