|
@@ -284,7 +284,7 @@ bitmap_ip_uadt(struct ip_set *set, struct nlattr *tb[],
|
|
|
} else if (tb[IPSET_ATTR_CIDR]) {
|
|
|
u8 cidr = nla_get_u8(tb[IPSET_ATTR_CIDR]);
|
|
|
|
|
|
- if (cidr > 32)
|
|
|
+ if (!cidr || cidr > 32)
|
|
|
return -IPSET_ERR_INVALID_CIDR;
|
|
|
ip_set_mask_from_to(ip, ip_to, cidr);
|
|
|
} else
|
|
@@ -454,7 +454,8 @@ static int
|
|
|
bitmap_ip_create(struct ip_set *set, struct nlattr *tb[], u32 flags)
|
|
|
{
|
|
|
struct bitmap_ip *map;
|
|
|
- u32 first_ip, last_ip, hosts, elements;
|
|
|
+ u32 first_ip, last_ip, hosts;
|
|
|
+ u64 elements;
|
|
|
u8 netmask = 32;
|
|
|
int ret;
|
|
|
|
|
@@ -497,7 +498,7 @@ bitmap_ip_create(struct ip_set *set, struct nlattr *tb[], u32 flags)
|
|
|
|
|
|
if (netmask == 32) {
|
|
|
hosts = 1;
|
|
|
- elements = last_ip - first_ip + 1;
|
|
|
+ elements = (u64)last_ip - first_ip + 1;
|
|
|
} else {
|
|
|
u8 mask_bits;
|
|
|
u32 mask;
|
|
@@ -515,7 +516,8 @@ bitmap_ip_create(struct ip_set *set, struct nlattr *tb[], u32 flags)
|
|
|
if (elements > IPSET_BITMAP_MAX_RANGE + 1)
|
|
|
return -IPSET_ERR_BITMAP_RANGE_SIZE;
|
|
|
|
|
|
- pr_debug("hosts %u, elements %u\n", hosts, elements);
|
|
|
+ pr_debug("hosts %u, elements %llu\n",
|
|
|
+ hosts, (unsigned long long)elements);
|
|
|
|
|
|
map = kzalloc(sizeof(*map), GFP_KERNEL);
|
|
|
if (!map)
|