mirror of
https://github.com/torvalds/linux.git
synced 2024-11-13 23:51:39 +00:00
Merge branch 'master' of git://1984.lsi.us.es/nf
Pablo Neira Ayuso says: ==================== The following patchset contains two bugfixes for netfilter/ipset via Jozsef Kadlecsik, they are: * Fix timeout corruption if sets are resized, by Josh Hunt. * Fix bogus error report if the flag nomatch is set, from Jozsef. ==================== Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
commit
b86c761f69
@ -854,6 +854,8 @@ type_pf_tresize(struct ip_set *set, bool retried)
|
|||||||
retry:
|
retry:
|
||||||
ret = 0;
|
ret = 0;
|
||||||
htable_bits++;
|
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) {
|
if (!htable_bits) {
|
||||||
/* In case we have plenty of memory :-) */
|
/* In case we have plenty of memory :-) */
|
||||||
pr_warning("Cannot increase the hashsize of set %s further\n",
|
pr_warning("Cannot increase the hashsize of set %s further\n",
|
||||||
@ -873,7 +875,7 @@ retry:
|
|||||||
data = ahash_tdata(n, j);
|
data = ahash_tdata(n, j);
|
||||||
m = hbucket(t, HKEY(data, h->initval, htable_bits));
|
m = hbucket(t, HKEY(data, h->initval, htable_bits));
|
||||||
ret = type_pf_elem_tadd(m, data, AHASH_MAX(h), 0,
|
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) {
|
if (ret < 0) {
|
||||||
read_unlock_bh(&set->lock);
|
read_unlock_bh(&set->lock);
|
||||||
ahash_destroy(t);
|
ahash_destroy(t);
|
||||||
|
@ -1470,7 +1470,8 @@ ip_set_utest(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
if (ret == -EAGAIN)
|
if (ret == -EAGAIN)
|
||||||
ret = 1;
|
ret = 1;
|
||||||
|
|
||||||
return ret < 0 ? ret : ret > 0 ? 0 : -IPSET_ERR_EXIST;
|
return (ret < 0 && ret != -ENOTEMPTY) ? ret :
|
||||||
|
ret > 0 ? 0 : -IPSET_ERR_EXIST;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Get headed data of a set */
|
/* Get headed data of a set */
|
||||||
|
Loading…
Reference in New Issue
Block a user