Added poisoning of free'd objects when we're debugging.
This commit is contained in:
parent
df9f0fb30a
commit
b8e60d3562
1 changed files with 7 additions and 0 deletions
|
@ -16,6 +16,10 @@
|
|||
|
||||
#undef FAKE_SLAB /* Turn on if you want to debug memory allocations */
|
||||
|
||||
#ifdef DEBUGGING
|
||||
#define POISON /* Poison all regions after they are freed */
|
||||
#endif
|
||||
|
||||
static void slab_free(resource *r);
|
||||
static void slab_dump(resource *r);
|
||||
static resource *slab_lookup(resource *r, unsigned long addr);
|
||||
|
@ -221,6 +225,9 @@ sl_free(slab *s, void *oo)
|
|||
struct sl_obj *o = SKIP_BACK(struct sl_obj, u.data, oo);
|
||||
struct sl_head *h = o->slab;
|
||||
|
||||
#ifdef POISON
|
||||
memset(oo, 0xdb, s->obj_size);
|
||||
#endif
|
||||
o->u.next = h->first_free;
|
||||
h->first_free = o;
|
||||
if (!--h->num_full)
|
||||
|
|
Loading…
Reference in a new issue