0
0
mirror of https://gitlab.nic.cz/labs/bird.git synced 2025-01-04 16:11:54 +00:00

Cleanup changes

This commit is contained in:
Ondrej Zajicek 2009-03-31 21:17:00 +02:00
parent b1a597e0c3
commit c60cdd8c39
2 changed files with 3 additions and 6 deletions

View File

@ -49,11 +49,6 @@
* final node (if it is not in the trie) and we came to node that * final node (if it is not in the trie) and we came to node that
* is either extension of our prefix, or completely out of path * is either extension of our prefix, or completely out of path
* In the first case, we also have to check M2. * In the first case, we also have to check M2.
* There also might be
* a problem that interval of acceptance (on path from root to the
* final node) might be completely missing (for example if we have
* prefix patterns 192.168.128.0/24{8,10} and 192.168.1.0/24
* *
* Second, we really need not to maintain two separate bitmasks. * Second, we really need not to maintain two separate bitmasks.
* Checks for mask M1 are always larger than &applen and we need * Checks for mask M1 are always larger than &applen and we need

View File

@ -52,12 +52,13 @@ u32_masklen(u32 x)
* *
* This function computes a integral part of binary logarithm of given * This function computes a integral part of binary logarithm of given
* integer @v and returns it. The computed value is also an index of the * integer @v and returns it. The computed value is also an index of the
* first non-zero bit position. * most significant non-zero bit position.
*/ */
u32 u32
u32_log2(u32 v) u32_log2(u32 v)
{ {
/* The code from http://www-graphics.stanford.edu/~seander/bithacks.html */
u32 r, shift; u32 r, shift;
r = (v > 0xFFFF) << 4; v >>= r; r = (v > 0xFFFF) << 4; v >>= r;
shift = (v > 0xFF ) << 3; v >>= shift; r |= shift; shift = (v > 0xFF ) << 3; v >>= shift; r |= shift;
@ -66,3 +67,4 @@ u32_log2(u32 v)
r |= (v >> 1); r |= (v >> 1);
return r; return r;
} }