Re: [PATCH] netfilter: ipset: timeout values corrupted on set resize

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

 



Hi Josh,

On Tue, 19 Feb 2013, Josh Hunt wrote:

> If a resize is triggered on a set with timeouts enabled, the timeout
> values will get corrupted when copying them to the new set. This occured
> b/c the wrong timeout value is supplied to type_pf_elem_tadd().
> 
> This also adds simple debug statement similar to the one in type_pf_resize().

That's a good catch and perfect patch.

I'm just at the checking phase of the next release, which required a 
fairly large rewriting of the types - and which, as a side effect, fixed 
this bug. If I won't be able to release the rewritten version by the 
weekend, I'm going to apply your patch and release an interim version.

Best regards,
Jozsef
 
> Signed-off-by: Josh Hunt <johunt@xxxxxxxxxx>
> ---
>  include/linux/netfilter/ipset/ip_set_ahash.h |    4 +++-
>  1 files changed, 3 insertions(+), 1 deletions(-)
> 
> diff --git a/include/linux/netfilter/ipset/ip_set_ahash.h b/include/linux/netfilter/ipset/ip_set_ahash.h
> index ef9acd3..01d25e6 100644
> --- a/include/linux/netfilter/ipset/ip_set_ahash.h
> +++ b/include/linux/netfilter/ipset/ip_set_ahash.h
> @@ -854,6 +854,8 @@ type_pf_tresize(struct ip_set *set, bool retried)
>  retry:
>  	ret = 0;
>  	htable_bits++;
> +	pr_debug("attempt to resize set %s from %u to %u, t %p\n",
> +		 set->name, orig->htable_bits, htable_bits, orig);
>  	if (!htable_bits) {
>  		/* In case we have plenty of memory :-) */
>  		pr_warning("Cannot increase the hashsize of set %s further\n",
> @@ -873,7 +875,7 @@ retry:
>  			data = ahash_tdata(n, j);
>  			m = hbucket(t, HKEY(data, h->initval, htable_bits));
>  			ret = type_pf_elem_tadd(m, data, AHASH_MAX(h), 0,
> -						type_pf_data_timeout(data));
> +						ip_set_timeout_get(type_pf_data_timeout(data)));
>  			if (ret < 0) {
>  				read_unlock_bh(&set->lock);
>  				ahash_destroy(t);
> -- 
> 1.7.0.4
> 

-
E-mail  : kadlec@xxxxxxxxxxxxxxxxx, kadlecsik.jozsef@xxxxxxxxxxxxx
PGP key : http://www.kfki.hu/~kadlec/pgp_public_key.txt
Address : Wigner Research Centre for Physics, Hungarian Academy of Sciences
          H-1525 Budapest 114, POB. 49, Hungary
--
To unsubscribe from this list: send the line "unsubscribe netfilter-devel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Netfitler Users]     [LARTC]     [Bugtraq]     [Yosemite Forum]

  Powered by Linux