nullb: use ida to manage index
authorShaohua Li <shli@fb.com>
Mon, 14 Aug 2017 22:04:55 +0000 (15:04 -0700)
committerJens Axboe <axboe@kernel.dk>
Wed, 23 Aug 2017 14:54:05 +0000 (08:54 -0600)
We now dynamically create disks. Managing the disk index with ida to
avoid bump up the index too much.

Signed-off-by: Shaohua Li <shli@fb.com>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
drivers/block/null_blk.c

index cf14c46d34625c87af58f09648308ccbb8a5004d..2f66627d8c4b10bcca38d34072cc0caad739efa9 100644 (file)
@@ -87,7 +87,7 @@ struct nullb {
 static LIST_HEAD(nullb_list);
 static struct mutex lock;
 static int null_major;
-static int nullb_indexes;
+static DEFINE_IDA(nullb_indexes);
 static struct kmem_cache *ppa_cache;
 static struct blk_mq_tag_set tag_set;
 
@@ -871,6 +871,8 @@ static void null_del_dev(struct nullb *nullb)
 {
        struct nullb_device *dev = nullb->dev;
 
+       ida_simple_remove(&nullb_indexes, nullb->index);
+
        list_del_init(&nullb->list);
 
        if (dev->use_lightnvm)
@@ -1118,7 +1120,7 @@ static int null_add_dev(struct nullb_device *dev)
        queue_flag_clear_unlocked(QUEUE_FLAG_ADD_RANDOM, nullb->q);
 
        mutex_lock(&lock);
-       nullb->index = nullb_indexes++;
+       nullb->index = ida_simple_get(&nullb_indexes, 0, 0, GFP_KERNEL);
        dev->index = nullb->index;
        mutex_unlock(&lock);