This is implemented in a way similar to lib/slists.h, but it took some more effort to make rehashing not disturb the readers. We do it by just taking _highest_ k bits of ipa_hash as our hash value and sorting each box by whole ipa_hash(). Consult FIB_ITERATE_* macros in nest/route.h. Implemented fib_check() debugging function and also rewrote the rehashing algorithm to use better thresholds and not to waste time by rehashing forth and back.
Description
This is a clone of the BIRD Internet Routing Daemon, used for building the bird daemon used in burble.dn42.
https://gitlab.labs.nic.cz/labs/bird
Languages
C
89.8%
Yacc
6.3%
M4
1.6%
Lex
0.8%
Makefile
0.5%
Other
1%