summaryrefslogtreecommitdiff
path: root/lib/ip.h
diff options
context:
space:
mode:
authorOndrej Zajicek (work) <santiago@crfreenet.org>2021-11-13 21:11:18 +0100
committerOndrej Zajicek (work) <santiago@crfreenet.org>2021-11-13 21:11:18 +0100
commit71c18d9f53ec0ea5eb512fdb6510d0c3350f96b4 (patch)
tree966b66c2a3e98561f774e8bf86c6d2b6d1eb652b /lib/ip.h
parent067f69a56de0e0e61d423ec5aa68095aa28e3124 (diff)
Trie: Simplify network matching code
Introduce ipX_prefix_equal() and use it to simplify network matching code.
Diffstat (limited to 'lib/ip.h')
-rw-r--r--lib/ip.h18
1 files changed, 18 insertions, 0 deletions
diff --git a/lib/ip.h b/lib/ip.h
index cc36ce64..9eef2e16 100644
--- a/lib/ip.h
+++ b/lib/ip.h
@@ -279,6 +279,24 @@ static inline uint ip6_pxlen(ip6_addr a, ip6_addr b)
return 32 * i + 31 - u32_log2(a.addr[i] ^ b.addr[i]);
}
+static inline int ip4_prefix_equal(ip4_addr a, ip4_addr b, uint n)
+{
+ return (_I(a) ^ _I(b)) < ((u64) 1 << (32 - n));
+}
+
+static inline int ip6_prefix_equal(ip6_addr a, ip6_addr b, uint n)
+{
+ uint n0 = n / 32;
+ uint n1 = n % 32;
+
+ return
+ ((n0 <= 0) || (_I0(a) == _I0(b))) &&
+ ((n0 <= 1) || (_I1(a) == _I1(b))) &&
+ ((n0 <= 2) || (_I2(a) == _I2(b))) &&
+ ((n0 <= 3) || (_I3(a) == _I3(b))) &&
+ (!n1 || ((a.addr[n0] ^ b.addr[n0]) < (1u << (32 - n1))));
+}
+
static inline u32 ip4_getbit(ip4_addr a, uint pos)
{ return (_I(a) >> (31 - pos)) & 1; }