mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-18 10:04:20 +03:00
[radix-tree] Add some extra checks to is_well_formed()
This commit is contained in:
parent
fdb6ef8a85
commit
abe2210c26
@ -1036,6 +1036,7 @@ void radix_tree_iterate(struct radix_tree *rt, uint8_t *kb, uint8_t *ke,
|
|||||||
|
|
||||||
static bool _check_nodes(struct value *v, unsigned *count)
|
static bool _check_nodes(struct value *v, unsigned *count)
|
||||||
{
|
{
|
||||||
|
uint64_t bits;
|
||||||
unsigned i, ncount;
|
unsigned i, ncount;
|
||||||
struct value_chain *vc;
|
struct value_chain *vc;
|
||||||
struct prefix_chain *pc;
|
struct prefix_chain *pc;
|
||||||
@ -1090,22 +1091,47 @@ static bool _check_nodes(struct value *v, unsigned *count)
|
|||||||
return true;
|
return true;
|
||||||
|
|
||||||
case NODE48:
|
case NODE48:
|
||||||
|
bits = 0;
|
||||||
n48 = v->value.ptr;
|
n48 = v->value.ptr;
|
||||||
ncount = 0;
|
ncount = 0;
|
||||||
for (i = 0; i < 256; i++) {
|
for (i = 0; i < 256; i++) {
|
||||||
if (n48->keys[i] < 48) {
|
if (n48->keys[i] < 48) {
|
||||||
|
if (n48->keys[i] >= n48->nr_entries) {
|
||||||
|
fprintf(stderr, "referencing value past nr_entries (n48)\n");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (bits & (1ull << n48->keys[i])) {
|
||||||
|
fprintf(stderr, "duplicate entry (n48) %u\n", (unsigned) n48->keys[i]);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
bits = bits | (1ull << n48->keys[i]);
|
||||||
ncount++;
|
ncount++;
|
||||||
|
|
||||||
if (!_check_nodes(n48->values + n48->keys[i], count))
|
if (!_check_nodes(n48->values + n48->keys[i], count))
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < n48->nr_entries; i++) {
|
||||||
|
if (!(bits & (1ull << i))) {
|
||||||
|
fprintf(stderr, "not all values are referenced (n48)\n");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (ncount != n48->nr_entries) {
|
if (ncount != n48->nr_entries) {
|
||||||
fprintf(stderr, "incorrect number of entries in n48, n48->nr_entries = %u, actual = %u\n",
|
fprintf(stderr, "incorrect number of entries in n48, n48->nr_entries = %u, actual = %u\n",
|
||||||
n48->nr_entries, ncount);
|
n48->nr_entries, ncount);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < n48->nr_entries; i++)
|
||||||
|
if (n48->values[i].type == UNSET) {
|
||||||
|
fprintf(stderr, "value in UNSET (n48)\n");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
for (i = n48->nr_entries; i < 48; i++)
|
for (i = n48->nr_entries; i < 48; i++)
|
||||||
if (n48->values[i].type != UNSET) {
|
if (n48->values[i].type != UNSET) {
|
||||||
fprintf(stderr, "unused value is not UNSET (n48)\n");
|
fprintf(stderr, "unused value is not UNSET (n48)\n");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user