block: remove bdget_disk

Just opencode the xa_load in the callers, as none of them actually
needs a reference to the bdev.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: Hannes Reinecke <hare@suse.de>
Reviewed-by: Ming Lei <ming.lei@redhat.com>
Link: https://lore.kernel.org/r/20210525061301.2242282-9-hch@lst.de
Signed-off-by: Jens Axboe <axboe@kernel.dk>
This commit is contained in:
Christoph Hellwig 2021-05-25 08:13:01 +02:00 committed by Jens Axboe
parent c97d93c31e
commit 0e0ccdecb3
3 changed files with 18 additions and 45 deletions

View File

@ -676,32 +676,6 @@ void blk_request_module(dev_t devt)
request_module("block-major-%d", MAJOR(devt)); request_module("block-major-%d", MAJOR(devt));
} }
/**
* bdget_disk - do bdget() by gendisk and partition number
* @disk: gendisk of interest
* @partno: partition number
*
* Find partition @partno from @disk, do bdget() on it.
*
* CONTEXT:
* Don't care.
*
* RETURNS:
* Resulting block_device on success, NULL on failure.
*/
struct block_device *bdget_disk(struct gendisk *disk, int partno)
{
struct block_device *bdev = NULL;
rcu_read_lock();
bdev = xa_load(&disk->part_tbl, partno);
if (bdev && !bdgrab(bdev))
bdev = NULL;
rcu_read_unlock();
return bdev;
}
/* /*
* print a full list of all partitions - intended for places where the root * print a full list of all partitions - intended for places where the root
* filesystem can't be mounted and thus to give the victim some idea of what * filesystem can't be mounted and thus to give the victim some idea of what
@ -1229,13 +1203,14 @@ module_init(proc_genhd_init);
dev_t part_devt(struct gendisk *disk, u8 partno) dev_t part_devt(struct gendisk *disk, u8 partno)
{ {
struct block_device *part = bdget_disk(disk, partno); struct block_device *part;
dev_t devt = 0; dev_t devt = 0;
if (part) { rcu_read_lock();
part = xa_load(&disk->part_tbl, partno);
if (part)
devt = part->bd_dev; devt = part->bd_dev;
bdput(part); rcu_read_unlock();
}
return devt; return devt;
} }

View File

@ -326,6 +326,8 @@ static struct block_device *add_partition(struct gendisk *disk, int partno,
const char *dname; const char *dname;
int err; int err;
lockdep_assert_held(&disk->open_mutex);
if (partno >= disk_max_parts(disk)) if (partno >= disk_max_parts(disk))
return ERR_PTR(-EINVAL); return ERR_PTR(-EINVAL);
@ -467,14 +469,13 @@ int bdev_add_partition(struct block_device *bdev, int partno,
int bdev_del_partition(struct block_device *bdev, int partno) int bdev_del_partition(struct block_device *bdev, int partno)
{ {
struct block_device *part; struct block_device *part = NULL;
int ret; int ret = -ENXIO;
part = bdget_disk(bdev->bd_disk, partno);
if (!part)
return -ENXIO;
mutex_lock(&bdev->bd_disk->open_mutex); mutex_lock(&bdev->bd_disk->open_mutex);
part = xa_load(&bdev->bd_disk->part_tbl, partno);
if (!part)
goto out_unlock;
ret = -EBUSY; ret = -EBUSY;
if (part->bd_openers) if (part->bd_openers)
@ -484,21 +485,20 @@ int bdev_del_partition(struct block_device *bdev, int partno)
ret = 0; ret = 0;
out_unlock: out_unlock:
mutex_unlock(&bdev->bd_disk->open_mutex); mutex_unlock(&bdev->bd_disk->open_mutex);
bdput(part);
return ret; return ret;
} }
int bdev_resize_partition(struct block_device *bdev, int partno, int bdev_resize_partition(struct block_device *bdev, int partno,
sector_t start, sector_t length) sector_t start, sector_t length)
{ {
struct block_device *part; struct block_device *part = NULL;
int ret = 0; int ret = -ENXIO;
part = bdget_disk(bdev->bd_disk, partno);
if (!part)
return -ENXIO;
mutex_lock(&bdev->bd_disk->open_mutex); mutex_lock(&bdev->bd_disk->open_mutex);
part = xa_load(&bdev->bd_disk->part_tbl, partno);
if (!part)
goto out_unlock;
ret = -EINVAL; ret = -EINVAL;
if (start != part->bd_start_sect) if (start != part->bd_start_sect)
goto out_unlock; goto out_unlock;
@ -512,7 +512,6 @@ int bdev_resize_partition(struct block_device *bdev, int partno,
ret = 0; ret = 0;
out_unlock: out_unlock:
mutex_unlock(&bdev->bd_disk->open_mutex); mutex_unlock(&bdev->bd_disk->open_mutex);
bdput(part);
return ret; return ret;
} }

View File

@ -223,7 +223,6 @@ static inline void add_disk_no_queue_reg(struct gendisk *disk)
} }
extern void del_gendisk(struct gendisk *gp); extern void del_gendisk(struct gendisk *gp);
extern struct block_device *bdget_disk(struct gendisk *disk, int partno);
void set_disk_ro(struct gendisk *disk, bool read_only); void set_disk_ro(struct gendisk *disk, bool read_only);