Re: [PATCH nf-next] netfilter: nf_tables: do not remove elements if set backend implements .abort

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Mon, Jul 15, 2024 at 04:15:56PM +0200, Pablo Neira Ayuso wrote:
> pipapo set backend maintains two copies of the datastructure, removing
> the elements from the copy that is going to be discarded slows down
> the abort path significantly, from several minutes to few seconds after
> this patch.
> 
> This patch was previously reverted by
> 
>   f86fb94011ae ("netfilter: nf_tables: revert do not remove elements if set backend implements .abort")
> 
> but it is now possible since recent work by Florian Westphal to perform
> on-demand clone from insert/remove path:
> 
>   532aec7e878b ("netfilter: nft_set_pipapo: remove dirty flag")
>   3f1d886cc7c3 ("netfilter: nft_set_pipapo: move cloning of match info to insert/removal path")
>   a238106703ab ("netfilter: nft_set_pipapo: prepare pipapo_get helper for on-demand clone")
>   c5444786d0ea ("netfilter: nft_set_pipapo: merge deactivate helper into caller")
>   6c108d9bee44 ("netfilter: nft_set_pipapo: prepare walk function for on-demand clone")
>   8b8a2417558c ("netfilter: nft_set_pipapo: prepare destroy function for on-demand clone")
>   80efd2997fb9 ("netfilter: nft_set_pipapo: make pipapo_clone helper return NULL")
>   a590f4760922 ("netfilter: nft_set_pipapo: move prove_locking helper around")
> 
> after this series, the clone is fully released once aborted, no need to
> take it back to previous state. Thus, no stale reference to elements can
> occur.

I have now rescued this patch and place it in nf-next.




[Index of Archives]     [Netfitler Users]     [Berkeley Packet Filter]     [LARTC]     [Bugtraq]     [Yosemite Forum]

  Powered by Linux