mirror of
https://gitlab.nic.cz/labs/bird.git
synced 2025-01-05 16:41:53 +00:00
Bugfix
Due to wrong cast of void pointer, pointers to potential buckets were compared and eventually sorted in wrong order, thus assigning wrong buckets to trie nodes. This caused some trie nodes to stay in trie even though they should have been removed. Consequently, trie contained superfluos prefixes after the algorithm finished. Since pointers were never dereferenced, only compared by their numeric values in the comparator function, program did not crash (even though pointers could be NULL because of the incorrect cast to double pointer and single dereference).
This commit is contained in:
parent
22060fe09f
commit
79981d2ad2
@ -234,8 +234,8 @@ aggregator_bucket_compare(const void *a, const void *b)
|
|||||||
if (b == NULL)
|
if (b == NULL)
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
const struct aggregator_bucket *fst = *(struct aggregator_bucket **)a;
|
const struct aggregator_bucket *fst = (struct aggregator_bucket *)a;
|
||||||
const struct aggregator_bucket *snd = *(struct aggregator_bucket **)b;
|
const struct aggregator_bucket *snd = (struct aggregator_bucket *)b;
|
||||||
|
|
||||||
/* There is linear ordering on pointers */
|
/* There is linear ordering on pointers */
|
||||||
if (fst < snd)
|
if (fst < snd)
|
||||||
|
Loading…
Reference in New Issue
Block a user