Skip to content

Commit

Permalink
Merge branch 'core/debugobjects' into core/urgent
Browse files Browse the repository at this point in the history
  • Loading branch information
Ingo Molnar committed Jun 27, 2008
2 parents 1b7558e + 50db04d commit d7ee560
Showing 1 changed file with 6 additions and 9 deletions.
15 changes: 6 additions & 9 deletions lib/debugobjects.c
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,7 @@ static int fill_pool(void)
{
gfp_t gfp = GFP_ATOMIC | __GFP_NORETRY | __GFP_NOWARN;
struct debug_obj *new;
unsigned long flags;

if (likely(obj_pool_free >= ODEBUG_POOL_MIN_LEVEL))
return obj_pool_free;
Expand All @@ -81,10 +82,10 @@ static int fill_pool(void)
if (!new)
return obj_pool_free;

spin_lock(&pool_lock);
spin_lock_irqsave(&pool_lock, flags);
hlist_add_head(&new->node, &obj_pool);
obj_pool_free++;
spin_unlock(&pool_lock);
spin_unlock_irqrestore(&pool_lock, flags);
}
return obj_pool_free;
}
Expand All @@ -110,16 +111,13 @@ static struct debug_obj *lookup_object(void *addr, struct debug_bucket *b)
}

/*
* Allocate a new object. If the pool is empty and no refill possible,
* switch off the debugger.
* Allocate a new object. If the pool is empty, switch off the debugger.
*/
static struct debug_obj *
alloc_object(void *addr, struct debug_bucket *b, struct debug_obj_descr *descr)
{
struct debug_obj *obj = NULL;
int retry = 0;

repeat:
spin_lock(&pool_lock);
if (obj_pool.first) {
obj = hlist_entry(obj_pool.first, typeof(*obj), node);
Expand All @@ -141,9 +139,6 @@ alloc_object(void *addr, struct debug_bucket *b, struct debug_obj_descr *descr)
}
spin_unlock(&pool_lock);

if (fill_pool() && !obj && !retry++)
goto repeat;

return obj;
}

Expand Down Expand Up @@ -261,6 +256,8 @@ __debug_object_init(void *addr, struct debug_obj_descr *descr, int onstack)
struct debug_obj *obj;
unsigned long flags;

fill_pool();

db = get_bucket((unsigned long) addr);

spin_lock_irqsave(&db->lock, flags);
Expand Down

0 comments on commit d7ee560

Please sign in to comment.