提交 cdd094fd 编写于 作者: J Jens Axboe

Revert "lightnvm: prevent bd removal if busy"

Christoph correctly points out that this issue is no different
for other block devices, and poking at cross layer internals
is not the right way to solve it.

This reverts commit bb6aa6f0.
Signed-off-by: NJens Axboe <axboe@kernel.dk>
上级 1a94b2d4
...@@ -390,7 +390,6 @@ static void __nvm_remove_target(struct nvm_target *t) ...@@ -390,7 +390,6 @@ static void __nvm_remove_target(struct nvm_target *t)
static int nvm_remove_tgt(struct nvm_dev *dev, struct nvm_ioctl_remove *remove) static int nvm_remove_tgt(struct nvm_dev *dev, struct nvm_ioctl_remove *remove)
{ {
struct nvm_target *t; struct nvm_target *t;
struct block_device *bdev;
mutex_lock(&dev->mlock); mutex_lock(&dev->mlock);
t = nvm_find_target(dev, remove->tgtname); t = nvm_find_target(dev, remove->tgtname);
...@@ -398,19 +397,6 @@ static int nvm_remove_tgt(struct nvm_dev *dev, struct nvm_ioctl_remove *remove) ...@@ -398,19 +397,6 @@ static int nvm_remove_tgt(struct nvm_dev *dev, struct nvm_ioctl_remove *remove)
mutex_unlock(&dev->mlock); mutex_unlock(&dev->mlock);
return 1; return 1;
} }
bdev = bdget_disk(t->disk, 0);
if (!bdev) {
pr_err("nvm: removal failed, allocating bd failed\n");
mutex_unlock(&dev->mlock);
return -ENOMEM;
}
if (bdev->bd_super || bdev->bd_part_count) {
pr_err("nvm: removal failed, block device busy\n");
bdput(bdev);
mutex_unlock(&dev->mlock);
return -EBUSY;
}
bdput(bdev);
__nvm_remove_target(t); __nvm_remove_target(t);
mutex_unlock(&dev->mlock); mutex_unlock(&dev->mlock);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册