|
@@ -884,6 +884,8 @@ static void bdev_evict_inode(struct inode *inode)
|
|
|
spin_lock(&bdev_lock);
|
|
|
list_del_init(&bdev->bd_list);
|
|
|
spin_unlock(&bdev_lock);
|
|
|
+ if (bdev->bd_bdi != &noop_backing_dev_info)
|
|
|
+ bdi_put(bdev->bd_bdi);
|
|
|
}
|
|
|
|
|
|
static const struct super_operations bdev_sops = {
|
|
@@ -986,6 +988,7 @@ struct block_device *bdget(dev_t dev)
|
|
|
bdev->bd_contains = NULL;
|
|
|
bdev->bd_super = NULL;
|
|
|
bdev->bd_inode = inode;
|
|
|
+ bdev->bd_bdi = &noop_backing_dev_info;
|
|
|
bdev->bd_block_size = (1 << inode->i_blkbits);
|
|
|
bdev->bd_part_count = 0;
|
|
|
bdev->bd_invalidated = 0;
|
|
@@ -1542,6 +1545,8 @@ static int __blkdev_get(struct block_device *bdev, fmode_t mode, int for_part)
|
|
|
bdev->bd_disk = disk;
|
|
|
bdev->bd_queue = disk->queue;
|
|
|
bdev->bd_contains = bdev;
|
|
|
+ if (bdev->bd_bdi == &noop_backing_dev_info)
|
|
|
+ bdev->bd_bdi = bdi_get(disk->queue->backing_dev_info);
|
|
|
|
|
|
if (!partno) {
|
|
|
ret = -ENXIO;
|
|
@@ -1637,6 +1642,8 @@ static int __blkdev_get(struct block_device *bdev, fmode_t mode, int for_part)
|
|
|
bdev->bd_disk = NULL;
|
|
|
bdev->bd_part = NULL;
|
|
|
bdev->bd_queue = NULL;
|
|
|
+ bdi_put(bdev->bd_bdi);
|
|
|
+ bdev->bd_bdi = &noop_backing_dev_info;
|
|
|
if (bdev != bdev->bd_contains)
|
|
|
__blkdev_put(bdev->bd_contains, mode, 1);
|
|
|
bdev->bd_contains = NULL;
|