pool: more strict checktree() for poolcheck
check that Free.next and Free.prev pointers are not nil. check that Free.left and Free.right are Poison in non-tree nodes. check that Free.left and Free.right are *not* Poison in tree nodes. change Poison to 0xffffffffcafebabe for 64bit machines.
This commit is contained in:
parent
384d4d2d62
commit
ef9c5b4cc7
1 changed files with 10 additions and 8 deletions
|
@ -123,7 +123,7 @@ enum {
|
||||||
|
|
||||||
static uchar datamagic[] = { 0xFE, 0xF1, 0xF0, 0xFA };
|
static uchar datamagic[] = { 0xFE, 0xF1, 0xF0, 0xFA };
|
||||||
|
|
||||||
#define Poison (void*)0xCafeBabe
|
#define Poison ((void*)-0x35014542) /* cafebabe */
|
||||||
|
|
||||||
#define _B2D(a) ((void*)((uchar*)a+sizeof(Bhdr)))
|
#define _B2D(a) ((void*)((uchar*)a+sizeof(Bhdr)))
|
||||||
#define _D2B(v) ((Alloc*)((uchar*)v-sizeof(Bhdr)))
|
#define _D2B(v) ((Alloc*)((uchar*)v-sizeof(Bhdr)))
|
||||||
|
@ -197,12 +197,12 @@ checklist(Free *t)
|
||||||
Free *q;
|
Free *q;
|
||||||
|
|
||||||
for(q=t->next; q!=t; q=q->next){
|
for(q=t->next; q!=t; q=q->next){
|
||||||
assert(q->size == t->size);
|
|
||||||
assert(q->next==nil || q->next->prev==q);
|
|
||||||
assert(q->prev==nil || q->prev->next==q);
|
|
||||||
// assert(q->left==nil);
|
|
||||||
// assert(q->right==nil);
|
|
||||||
assert(q->magic==FREE_MAGIC);
|
assert(q->magic==FREE_MAGIC);
|
||||||
|
assert(q->size==t->size);
|
||||||
|
assert(q->left==Poison);
|
||||||
|
assert(q->right==Poison);
|
||||||
|
assert(q->next!=nil && q->next!=Poison && q->next->prev==q);
|
||||||
|
assert(q->prev!=nil && q->prev!=Poison && q->prev->next==q);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -211,8 +211,10 @@ checktree(Free *t, int a, int b)
|
||||||
{
|
{
|
||||||
assert(t->magic==FREE_MAGIC);
|
assert(t->magic==FREE_MAGIC);
|
||||||
assert(a < t->size && t->size < b);
|
assert(a < t->size && t->size < b);
|
||||||
assert(t->next==nil || t->next->prev==t);
|
assert(t->left!=Poison);
|
||||||
assert(t->prev==nil || t->prev->next==t);
|
assert(t->right!=Poison);
|
||||||
|
assert(t->next!=nil && t->next!=Poison && t->next->prev==t);
|
||||||
|
assert(t->prev!=nil && t->prev!=Poison && t->prev->next==t);
|
||||||
checklist(t);
|
checklist(t);
|
||||||
if(t->left)
|
if(t->left)
|
||||||
checktree(t->left, a, t->size);
|
checktree(t->left, a, t->size);
|
||||||
|
|
Loading…
Reference in a new issue