mtd_blkdevs: simplify blktrans_dev_get
->private_data is set before the disk is added and never cleared, so don't bother trying to handle a NULL pointer there. Signed-off-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Miquel Raynal <miquel.raynal@bootlin.com> Link: https://lore.kernel.org/linux-mtd/20210823073359.705281-6-hch@lst.de
This commit is contained in:
parent
a0faf5fdfb
commit
8984382839
@ -39,16 +39,12 @@ static void blktrans_dev_release(struct kref *kref)
|
|||||||
|
|
||||||
static struct mtd_blktrans_dev *blktrans_dev_get(struct gendisk *disk)
|
static struct mtd_blktrans_dev *blktrans_dev_get(struct gendisk *disk)
|
||||||
{
|
{
|
||||||
struct mtd_blktrans_dev *dev;
|
struct mtd_blktrans_dev *dev = disk->private_data;
|
||||||
|
|
||||||
mutex_lock(&blktrans_ref_mutex);
|
mutex_lock(&blktrans_ref_mutex);
|
||||||
dev = disk->private_data;
|
|
||||||
|
|
||||||
if (!dev)
|
|
||||||
goto unlock;
|
|
||||||
kref_get(&dev->ref);
|
kref_get(&dev->ref);
|
||||||
unlock:
|
|
||||||
mutex_unlock(&blktrans_ref_mutex);
|
mutex_unlock(&blktrans_ref_mutex);
|
||||||
|
|
||||||
return dev;
|
return dev;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -204,9 +200,6 @@ static int blktrans_open(struct block_device *bdev, fmode_t mode)
|
|||||||
struct mtd_blktrans_dev *dev = blktrans_dev_get(bdev->bd_disk);
|
struct mtd_blktrans_dev *dev = blktrans_dev_get(bdev->bd_disk);
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
if (!dev)
|
|
||||||
return -ERESTARTSYS; /* FIXME: busy loop! -arnd*/
|
|
||||||
|
|
||||||
mutex_lock(&dev->lock);
|
mutex_lock(&dev->lock);
|
||||||
|
|
||||||
if (dev->open)
|
if (dev->open)
|
||||||
@ -250,9 +243,6 @@ static void blktrans_release(struct gendisk *disk, fmode_t mode)
|
|||||||
{
|
{
|
||||||
struct mtd_blktrans_dev *dev = blktrans_dev_get(disk);
|
struct mtd_blktrans_dev *dev = blktrans_dev_get(disk);
|
||||||
|
|
||||||
if (!dev)
|
|
||||||
return;
|
|
||||||
|
|
||||||
mutex_lock(&dev->lock);
|
mutex_lock(&dev->lock);
|
||||||
|
|
||||||
if (--dev->open)
|
if (--dev->open)
|
||||||
@ -276,9 +266,6 @@ static int blktrans_getgeo(struct block_device *bdev, struct hd_geometry *geo)
|
|||||||
struct mtd_blktrans_dev *dev = blktrans_dev_get(bdev->bd_disk);
|
struct mtd_blktrans_dev *dev = blktrans_dev_get(bdev->bd_disk);
|
||||||
int ret = -ENXIO;
|
int ret = -ENXIO;
|
||||||
|
|
||||||
if (!dev)
|
|
||||||
return ret;
|
|
||||||
|
|
||||||
mutex_lock(&dev->lock);
|
mutex_lock(&dev->lock);
|
||||||
|
|
||||||
if (!dev->mtd)
|
if (!dev->mtd)
|
||||||
|
Loading…
Reference in New Issue
Block a user