diff options
author | Alex Elder <elder@inktank.com> | 2012-10-10 21:19:13 -0700 |
---|---|---|
committer | Alex Elder <elder@inktank.com> | 2012-10-26 17:18:08 -0500 |
commit | b213e0b1a62637b2a9395a34349b13d73ca2b90a (patch) | |
tree | e096a1d0b33102ed8e433da468b45e0a9eede1c4 /drivers/block | |
parent | b000056a5a8d3f5a4a9fb80184a7ec14f86a43d4 (diff) | |
download | op-kernel-dev-b213e0b1a62637b2a9395a34349b13d73ca2b90a.zip op-kernel-dev-b213e0b1a62637b2a9395a34349b13d73ca2b90a.tar.gz |
rbd: fix bug in rbd_dev_id_put()
In rbd_dev_id_put(), there's a loop that's intended to determine
the maximum device id in use. But it isn't doing that at all,
the effect of how it's written is to simply use the just-put id
number, which ignores whole purpose of this function.
Fix the bug.
Signed-off-by: Alex Elder <elder@inktank.com>
Reviewed-by: Josh Durgin <josh.durgin@inktank.com>
Diffstat (limited to 'drivers/block')
-rw-r--r-- | drivers/block/rbd.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/block/rbd.c b/drivers/block/rbd.c index 8f56d37..4a16464 100644 --- a/drivers/block/rbd.c +++ b/drivers/block/rbd.c @@ -2680,8 +2680,8 @@ static void rbd_dev_id_put(struct rbd_device *rbd_dev) struct rbd_device *rbd_dev; rbd_dev = list_entry(tmp, struct rbd_device, node); - if (rbd_id > max_id) - max_id = rbd_id; + if (rbd_dev->dev_id > max_id) + max_id = rbd_dev->dev_id; } spin_unlock(&rbd_dev_list_lock); |