Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 6f14a668 authored by Tejun Heo's avatar Tejun Heo Committed by Linus Torvalds
Browse files

idr: revert misallocation bug fix



Commit 859ddf09 tried to fix
misallocation bug but broke full bit marking by not clearing
pa[idp->layers] and also is causing X failures due to lookup failure
in drm code.  The cause of the latter hasn't been found yet.  Revert
the fix for now.

Signed-off-by: default avatarTejun Heo <tj@kernel.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent e9e70bc1
Loading
Loading
Loading
Loading
+4 −3
Original line number Diff line number Diff line
@@ -140,7 +140,8 @@ static int sub_alloc(struct idr *idp, int *starting_id, struct idr_layer **pa)
	id = *starting_id;
 restart:
	p = idp->top;
	l = p->layer;
	l = idp->layers;
	pa[l--] = NULL;
	while (1) {
		/*
		 * We run around this while until we reach the leaf node...
@@ -154,8 +155,8 @@ static int sub_alloc(struct idr *idp, int *starting_id, struct idr_layer **pa)
			oid = id;
			id = (id | ((1 << (IDR_BITS * l)) - 1)) + 1;

			/* did id go over the limit? */
			if (id >= (1 << (idp->layers * IDR_BITS))) {
			/* if already at the top layer, we need to grow */
			if (!(p = pa[l])) {
				*starting_id = id;
				return IDR_NEED_TO_GROW;
			}