diff options
| author | Tejun Heo <tj@kernel.org> | 2010-02-04 03:57:37 -0500 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2010-02-04 19:03:41 -0500 |
| commit | 6f14a668f1a8b715a6e855f4e32705e54a6e86a1 (patch) | |
| tree | 3583162191f16c1d622fe1f6872870e6ae3fbfe8 | |
| parent | e9e70bc14ea5974e21f5baecf95a123844c412b9 (diff) | |
idr: revert misallocation bug fix
Commit 859ddf09743a8cc680af33f7259ccd0fd36bfe9d 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: Tejun Heo <tj@kernel.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
| -rw-r--r-- | lib/idr.c | 7 |
1 files changed, 4 insertions, 3 deletions
| @@ -140,7 +140,8 @@ static int sub_alloc(struct idr *idp, int *starting_id, struct idr_layer **pa) | |||
| 140 | id = *starting_id; | 140 | id = *starting_id; |
| 141 | restart: | 141 | restart: |
| 142 | p = idp->top; | 142 | p = idp->top; |
| 143 | l = p->layer; | 143 | l = idp->layers; |
| 144 | pa[l--] = NULL; | ||
| 144 | while (1) { | 145 | while (1) { |
| 145 | /* | 146 | /* |
| 146 | * We run around this while until we reach the leaf node... | 147 | * 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) | |||
| 154 | oid = id; | 155 | oid = id; |
| 155 | id = (id | ((1 << (IDR_BITS * l)) - 1)) + 1; | 156 | id = (id | ((1 << (IDR_BITS * l)) - 1)) + 1; |
| 156 | 157 | ||
| 157 | /* did id go over the limit? */ | 158 | /* if already at the top layer, we need to grow */ |
| 158 | if (id >= (1 << (idp->layers * IDR_BITS))) { | 159 | if (!(p = pa[l])) { |
| 159 | *starting_id = id; | 160 | *starting_id = id; |
| 160 | return IDR_NEED_TO_GROW; | 161 | return IDR_NEED_TO_GROW; |
| 161 | } | 162 | } |
