summaryrefslogtreecommitdiffstatshomepage
path: root/src/version.h
diff options
context:
space:
mode:
authorJason A. Donenfeld <Jason@zx2c4.com>2017-04-14 18:51:15 +0200
committerJason A. Donenfeld <Jason@zx2c4.com>2017-04-21 04:31:26 +0200
commit800fff7616d6d5258cb4c68d192c450762b1d34b (patch)
tree98bd1ca409e94d52840b1806c478e44e3747fac9 /src/version.h
parentcompat: work on old 3.10 (diff)
downloadwireguard-monolithic-historical-800fff7616d6d5258cb4c68d192c450762b1d34b.tar.xz
wireguard-monolithic-historical-800fff7616d6d5258cb4c68d192c450762b1d34b.zip
routingtable: rewrite core functions
When removing by peer, prev needs to be set to *nptr in order to traverse that part of the trie. The other remove by IP function can simply be removed, as it's not in use. The root freeing function can use pre-order traversal instead of post-order. The pre-order traversal code in general is now a nice iterator macro. The common bits function can use the fast fls instructions and the match function can be rewritten to simply compare common bits. While we're at it, let's add tons of new tests, randomized checking against a dumb implementation, and graphviz output. And in general, it's nice to clean things up.
Diffstat (limited to 'src/version.h')
0 files changed, 0 insertions, 0 deletions