Commit af8e2a4c authored by Nadia Derbey's avatar Nadia Derbey Committed by Linus Torvalds

idr: fix idr_remove()

The return inside the loop makes us free only a single layer.
Signed-off-by: default avatarNadia Derbey <Nadia.Derbey@bull.net>
Cc: "Paul E. McKenney" <paulmck@us.ibm.com>
Cc: Manfred Spraul <manfred@colorfullife.com>
Cc: Jim Houston <jim.houston@comcast.net>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 7793bfcf
...@@ -385,8 +385,8 @@ void idr_remove(struct idr *idp, int id) ...@@ -385,8 +385,8 @@ void idr_remove(struct idr *idp, int id)
while (idp->id_free_cnt >= IDR_FREE_MAX) { while (idp->id_free_cnt >= IDR_FREE_MAX) {
p = alloc_layer(idp); p = alloc_layer(idp);
kmem_cache_free(idr_layer_cache, p); kmem_cache_free(idr_layer_cache, p);
return;
} }
return;
} }
EXPORT_SYMBOL(idr_remove); EXPORT_SYMBOL(idr_remove);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment