util/cidr: simplify IPv4 CIDR handling; add IPv6

Instead of building a table at init just calculate it on demand.

Callsites are all during init, so its not performance critical.

Add similar function for IPv6.
pull/7018/head
Victor Julien 3 years ago
parent e04fcfcf2f
commit e04d378e58

@ -237,8 +237,6 @@ void RunUnittests(int list_unittests, const char *regex_arg)
SigTableSetup(); /* load the rule keywords */
TmqhSetup();
CIDRInit();
TagInitCtx();
SCReferenceConfInit();
SCClassConfInit();

@ -2664,8 +2664,6 @@ int PostConfLoadedSetup(SCInstance *suri)
SigTableApplyStrictCommandlineOption(suri->strict_rule_parsing_string);
TmqhSetup();
CIDRInit();
TagInitCtx();
PacketAlertTagInit();
ThresholdInit();

@ -1,4 +1,4 @@
/* Copyright (C) 2007-2010 Open Information Security Foundation
/* Copyright (C) 2007-2022 Open Information Security Foundation
*
* You can copy, redistribute or modify this Program under the terms of
* the GNU General Public License version 2 as published by the Free
@ -26,24 +26,46 @@
#include "suricata-common.h"
#include "util-cidr.h"
static uint32_t cidrs[33];
uint32_t CIDRGet(int cidr)
{
if (cidr <= 0 || cidr > 32)
return 0;
uint32_t netmask = htonl(0xFFFFFFFF << (32UL - (uint32_t)cidr));
SCLogDebug("CIDR %d -> netmask %08X", cidr, netmask);
return netmask;
}
void CIDRInit(void)
/**
* \brief Creates a cidr ipv6 netblock, based on the cidr netblock value.
*
* For example if we send a cidr of 7 as argument, an ipv6 address
* mask of the value FE:00:00:00:00:00:00:00 is created and updated
* in the argument struct in6_addr *in6.
*
* \todo I think for the final section: while (cidr > 0), we can simply
* replace it with a
* if (cidr > 0) {
* in6->s6_addr[i] = -1 << (8 - cidr);
*
* \param cidr The value of the cidr.
* \param in6 Pointer to an ipv6 address structure(struct in6_addr) which will
* hold the cidr netblock result.
*/
void CIDRGetIPv6(int cidr, struct in6_addr *in6)
{
int i = 0;
/* skip 0 as it will result in 0xffffffff */
cidrs[0] = 0;
for (i = 1; i < 33; i++) {
cidrs[i] = htonl(0xFFFFFFFF << (32 - i));
//printf("CIDRInit: cidrs[%02d] = 0x%08X\n", i, cidrs[i]);
memset(in6, 0, sizeof(struct in6_addr));
while (cidr > 8) {
in6->s6_addr[i] = 0xff;
cidr -= 8;
i++;
}
}
uint32_t CIDRGet(int cidr)
{
if (cidr < 0 || cidr > 32)
return 0;
return cidrs[cidr];
while (cidr > 0) {
in6->s6_addr[i] |= 0x80;
if (--cidr > 0)
in6->s6_addr[i] = in6->s6_addr[i] >> 1;
}
}

@ -24,8 +24,8 @@
#ifndef __UTIL_NETMASK_H__
#define __UTIL_NETMASK_H__
void CIDRInit(void);
uint32_t CIDRGet(int);
void CIDRGetIPv6(int cidr, struct in6_addr *in6);
#endif /* __UTIL_NETMASK_H__ */

Loading…
Cancel
Save