]> git.ipfire.org Git - thirdparty/ipset.git/commitdiff
netfilter: ipset: Check CIDR value only when attribute is given
authorSergey Popovich <popovich_sergei@mail.ua>
Mon, 17 Nov 2014 16:45:10 +0000 (18:45 +0200)
committerJozsef Kadlecsik <kadlec@blackhole.kfki.hu>
Fri, 20 Mar 2015 18:16:45 +0000 (19:16 +0100)
There is no reason to check CIDR value regardless attribute
specifying CIDR is given.

Initialize cidr array in element structure on element structure
declaration to let more freedom to the compiler to optimize
initialization right before element structure is used.

Remove local variables cidr and cidr2 for netnet and netportnet
hashes as we do not use packed cidr value for such set types and
can store value directly in e.cidr[].

Signed-off-by: Sergey Popovich <popovich_sergei@mail.ua>
Signed-off-by: Jozsef Kadlecsik <kadlec@blackhole.kfki.hu>
kernel/net/netfilter/ipset/ip_set_hash_net.c
kernel/net/netfilter/ipset/ip_set_hash_netiface.c
kernel/net/netfilter/ipset/ip_set_hash_netnet.c
kernel/net/netfilter/ipset/ip_set_hash_netportnet.c

index 1f148f515d36fa0912b09fdcf07aa41274c18798..01fe64a0637ae538bcf3af2f4e378ef03beb15c0 100644 (file)
@@ -330,11 +330,11 @@ hash_net6_uadt(struct ip_set *set, struct nlattr *tb[],
        if (ret)
                return ret;
 
-       if (tb[IPSET_ATTR_CIDR])
+       if (tb[IPSET_ATTR_CIDR]) {
                e.cidr = nla_get_u8(tb[IPSET_ATTR_CIDR]);
-
-       if (!e.cidr || e.cidr > HOST_MASK)
-               return -IPSET_ERR_INVALID_CIDR;
+               if (!e.cidr || e.cidr > HOST_MASK)
+                       return -IPSET_ERR_INVALID_CIDR;
+       }
 
        ip6_netmask(&e.ip, e.cidr);
 
index cb8e688cd036d485af46110de3ab214b9c6df2c3..29d42d00072a3c1ce29406b80a8c74705bee8b9d 100644 (file)
@@ -417,10 +417,12 @@ hash_netiface6_uadt(struct ip_set *set, struct nlattr *tb[],
        if (ret)
                return ret;
 
-       if (tb[IPSET_ATTR_CIDR])
+       if (tb[IPSET_ATTR_CIDR]) {
                e.cidr = nla_get_u8(tb[IPSET_ATTR_CIDR]);
-       if (e.cidr > HOST_MASK)
-               return -IPSET_ERR_INVALID_CIDR;
+               if (e.cidr > HOST_MASK)
+                       return -IPSET_ERR_INVALID_CIDR;
+       }
+
        ip6_netmask(&e.ip, e.cidr);
 
        nla_strlcpy(e.iface, tb[IPSET_ATTR_IFACE], IFNAMSIZ);
index 60faa3a763b5700108db353d7fb03531e3cf11af..f86f6e5d0276ce3c7b3e8d33f37e67908f9283e7 100644 (file)
@@ -160,17 +160,15 @@ hash_netnet4_uadt(struct ip_set *set, struct nlattr *tb[],
 {
        const struct hash_netnet *h = set->data;
        ipset_adtfn adtfn = set->variant->adt[adt];
-       struct hash_netnet4_elem e = { };
+       struct hash_netnet4_elem e = { .cidr = { HOST_MASK, HOST_MASK, }, };
        struct ip_set_ext ext = IP_SET_INIT_UEXT(set);
        u32 ip = 0, ip_to = 0, last;
        u32 ip2 = 0, ip2_from = 0, ip2_to = 0, last2;
-       u8 cidr, cidr2;
        int ret;
 
        if (tb[IPSET_ATTR_LINENO])
                *lineno = nla_get_u32(tb[IPSET_ATTR_LINENO]);
 
-       e.cidr[0] = e.cidr[1] = HOST_MASK;
        if (unlikely(!tb[IPSET_ATTR_IP] || !tb[IPSET_ATTR_IP2] ||
                     !ip_set_optattr_netorder(tb, IPSET_ATTR_CADT_FLAGS)))
                return -IPSET_ERR_PROTOCOL;
@@ -188,17 +186,15 @@ hash_netnet4_uadt(struct ip_set *set, struct nlattr *tb[],
                return ret;
 
        if (tb[IPSET_ATTR_CIDR]) {
-               cidr = nla_get_u8(tb[IPSET_ATTR_CIDR]);
-               if (!cidr || cidr > HOST_MASK)
+               e.cidr[0] = nla_get_u8(tb[IPSET_ATTR_CIDR]);
+               if (!e.cidr[0] || e.cidr[0] > HOST_MASK)
                        return -IPSET_ERR_INVALID_CIDR;
-               e.cidr[0] = cidr;
        }
 
        if (tb[IPSET_ATTR_CIDR2]) {
-               cidr2 = nla_get_u8(tb[IPSET_ATTR_CIDR2]);
-               if (!cidr2 || cidr2 > HOST_MASK)
+               e.cidr[1] = nla_get_u8(tb[IPSET_ATTR_CIDR2]);
+               if (!e.cidr[1] || e.cidr[1] > HOST_MASK)
                        return -IPSET_ERR_INVALID_CIDR;
-               e.cidr[1] = cidr2;
        }
 
        if (tb[IPSET_ATTR_CADT_FLAGS]) {
@@ -248,15 +244,13 @@ hash_netnet4_uadt(struct ip_set *set, struct nlattr *tb[],
 
        while (!after(ip, ip_to)) {
                e.ip[0] = htonl(ip);
-               last = ip_set_range_to_cidr(ip, ip_to, &cidr);
-               e.cidr[0] = cidr;
+               last = ip_set_range_to_cidr(ip, ip_to, &e.cidr[0]);
                ip2 = (retried &&
                       ip == ntohl(h->next.ip[0])) ? ntohl(h->next.ip[1])
                                                   : ip2_from;
                while (!after(ip2, ip2_to)) {
                        e.ip[1] = htonl(ip2);
-                       last2 = ip_set_range_to_cidr(ip2, ip2_to, &cidr2);
-                       e.cidr[1] = cidr2;
+                       last2 = ip_set_range_to_cidr(ip2, ip2_to, &e.cidr[1]);
                        ret = adtfn(set, &e, &ext, &ext, flags);
                        if (ret && !ip_set_eexist(ret, flags))
                                return ret;
@@ -391,14 +385,13 @@ hash_netnet6_uadt(struct ip_set *set, struct nlattr *tb[],
                  enum ipset_adt adt, u32 *lineno, u32 flags, bool retried)
 {
        ipset_adtfn adtfn = set->variant->adt[adt];
-       struct hash_netnet6_elem e = { };
+       struct hash_netnet6_elem e = { .cidr = { HOST_MASK, HOST_MASK, }, };
        struct ip_set_ext ext = IP_SET_INIT_UEXT(set);
        int ret;
 
        if (tb[IPSET_ATTR_LINENO])
                *lineno = nla_get_u32(tb[IPSET_ATTR_LINENO]);
 
-       e.cidr[0] = e.cidr[1] = HOST_MASK;
        if (unlikely(!tb[IPSET_ATTR_IP] || !tb[IPSET_ATTR_IP2] ||
                     !ip_set_optattr_netorder(tb, IPSET_ATTR_CADT_FLAGS)))
                return -IPSET_ERR_PROTOCOL;
@@ -417,15 +410,17 @@ hash_netnet6_uadt(struct ip_set *set, struct nlattr *tb[],
        if (ret)
                return ret;
 
-       if (tb[IPSET_ATTR_CIDR])
+       if (tb[IPSET_ATTR_CIDR]) {
                e.cidr[0] = nla_get_u8(tb[IPSET_ATTR_CIDR]);
+               if (!e.cidr[0] || e.cidr[0] > HOST_MASK)
+                       return -IPSET_ERR_INVALID_CIDR;
+       }
 
-       if (tb[IPSET_ATTR_CIDR2])
+       if (tb[IPSET_ATTR_CIDR2]) {
                e.cidr[1] = nla_get_u8(tb[IPSET_ATTR_CIDR2]);
-
-       if (!e.cidr[0] || e.cidr[0] > HOST_MASK || !e.cidr[1] ||
-           e.cidr[1] > HOST_MASK)
-               return -IPSET_ERR_INVALID_CIDR;
+               if (!e.cidr[1] || e.cidr[1] > HOST_MASK)
+                       return -IPSET_ERR_INVALID_CIDR;
+       }
 
        ip6_netmask(&e.ip[0], e.cidr[0]);
        ip6_netmask(&e.ip[1], e.cidr[1]);
index cf3442dd3bb9309d1402c2497bf974e562d28833..3fe3afc8af29631fcb3e7b8b3989d78193bb2172 100644 (file)
@@ -175,18 +175,16 @@ hash_netportnet4_uadt(struct ip_set *set, struct nlattr *tb[],
 {
        const struct hash_netportnet *h = set->data;
        ipset_adtfn adtfn = set->variant->adt[adt];
-       struct hash_netportnet4_elem e = { };
+       struct hash_netportnet4_elem e = { .cidr = { HOST_MASK, HOST_MASK, }, };
        struct ip_set_ext ext = IP_SET_INIT_UEXT(set);
        u32 ip = 0, ip_to = 0, ip_last, p = 0, port, port_to;
        u32 ip2_from = 0, ip2_to = 0, ip2_last, ip2;
        bool with_ports = false;
-       u8 cidr, cidr2;
        int ret;
 
        if (tb[IPSET_ATTR_LINENO])
                *lineno = nla_get_u32(tb[IPSET_ATTR_LINENO]);
 
-       e.cidr[0] = e.cidr[1] = HOST_MASK;
        if (unlikely(!tb[IPSET_ATTR_IP] || !tb[IPSET_ATTR_IP2] ||
                     !ip_set_attr_netorder(tb, IPSET_ATTR_PORT) ||
                     !ip_set_optattr_netorder(tb, IPSET_ATTR_PORT_TO) ||
@@ -206,17 +204,15 @@ hash_netportnet4_uadt(struct ip_set *set, struct nlattr *tb[],
                return ret;
 
        if (tb[IPSET_ATTR_CIDR]) {
-               cidr = nla_get_u8(tb[IPSET_ATTR_CIDR]);
-               if (!cidr || cidr > HOST_MASK)
+               e.cidr[0] = nla_get_u8(tb[IPSET_ATTR_CIDR]);
+               if (!e.cidr[0] || e.cidr[0] > HOST_MASK)
                        return -IPSET_ERR_INVALID_CIDR;
-               e.cidr[0] = cidr;
        }
 
        if (tb[IPSET_ATTR_CIDR2]) {
-               cidr = nla_get_u8(tb[IPSET_ATTR_CIDR2]);
-               if (!cidr || cidr > HOST_MASK)
+               e.cidr[1] = nla_get_u8(tb[IPSET_ATTR_CIDR2]);
+               if (!e.cidr[1] || e.cidr[1] > HOST_MASK)
                        return -IPSET_ERR_INVALID_CIDR;
-               e.cidr[1] = cidr;
        }
 
        e.port = nla_get_be16(tb[IPSET_ATTR_PORT]);
@@ -289,8 +285,7 @@ hash_netportnet4_uadt(struct ip_set *set, struct nlattr *tb[],
 
        while (!after(ip, ip_to)) {
                e.ip[0] = htonl(ip);
-               ip_last = ip_set_range_to_cidr(ip, ip_to, &cidr);
-               e.cidr[0] = cidr;
+               ip_last = ip_set_range_to_cidr(ip, ip_to, &e.cidr[0]);
                p = retried && ip == ntohl(h->next.ip[0]) ? ntohs(h->next.port)
                                                          : port;
                for (; p <= port_to; p++) {
@@ -301,8 +296,7 @@ hash_netportnet4_uadt(struct ip_set *set, struct nlattr *tb[],
                        while (!after(ip2, ip2_to)) {
                                e.ip[1] = htonl(ip2);
                                ip2_last = ip_set_range_to_cidr(ip2, ip2_to,
-                                                               &cidr2);
-                               e.cidr[1] = cidr2;
+                                                               &e.cidr[1]);
                                ret = adtfn(set, &e, &ext, &ext, flags);
                                if (ret && !ip_set_eexist(ret, flags))
                                        return ret;
@@ -451,7 +445,7 @@ hash_netportnet6_uadt(struct ip_set *set, struct nlattr *tb[],
 {
        const struct hash_netportnet *h = set->data;
        ipset_adtfn adtfn = set->variant->adt[adt];
-       struct hash_netportnet6_elem e = { };
+       struct hash_netportnet6_elem e = { .cidr = { HOST_MASK, HOST_MASK, }, };
        struct ip_set_ext ext = IP_SET_INIT_UEXT(set);
        u32 port, port_to;
        bool with_ports = false;
@@ -460,7 +454,6 @@ hash_netportnet6_uadt(struct ip_set *set, struct nlattr *tb[],
        if (tb[IPSET_ATTR_LINENO])
                *lineno = nla_get_u32(tb[IPSET_ATTR_LINENO]);
 
-       e.cidr[0] = e.cidr[1] = HOST_MASK;
        if (unlikely(!tb[IPSET_ATTR_IP] || !tb[IPSET_ATTR_IP2] ||
                     !ip_set_attr_netorder(tb, IPSET_ATTR_PORT) ||
                     !ip_set_optattr_netorder(tb, IPSET_ATTR_PORT_TO) ||
@@ -481,15 +474,17 @@ hash_netportnet6_uadt(struct ip_set *set, struct nlattr *tb[],
        if (ret)
                return ret;
 
-       if (tb[IPSET_ATTR_CIDR])
+       if (tb[IPSET_ATTR_CIDR]) {
                e.cidr[0] = nla_get_u8(tb[IPSET_ATTR_CIDR]);
+               if (!e.cidr[0] || e.cidr[0] > HOST_MASK)
+                       return -IPSET_ERR_INVALID_CIDR;
+       }
 
-       if (tb[IPSET_ATTR_CIDR2])
+       if (tb[IPSET_ATTR_CIDR2]) {
                e.cidr[1] = nla_get_u8(tb[IPSET_ATTR_CIDR2]);
-
-       if (unlikely(!e.cidr[0] || e.cidr[0] > HOST_MASK || !e.cidr[1] ||
-                    e.cidr[1] > HOST_MASK))
-               return -IPSET_ERR_INVALID_CIDR;
+               if (!e.cidr[1] || e.cidr[1] > HOST_MASK)
+                       return -IPSET_ERR_INVALID_CIDR;
+       }
 
        ip6_netmask(&e.ip[0], e.cidr[0]);
        ip6_netmask(&e.ip[1], e.cidr[1]);