]> www.infradead.org Git - users/hch/block.git/commitdiff
block: add a bdget_part helper bdget
authorChristoph Hellwig <hch@lst.de>
Wed, 23 Sep 2020 18:33:40 +0000 (20:33 +0200)
committerChristoph Hellwig <hch@lst.de>
Wed, 23 Sep 2020 18:34:40 +0000 (20:34 +0200)
All remaining callers of bdget() outside of fs/block_dev.c want to get a
reference to the struct block_device for a given struct hd_struct.  Add
a helper just for that and then mark bdget static.

Signed-off-by: Christoph Hellwig <hch@lst.de>
block/genhd.c
block/partitions/core.c
fs/block_dev.c
include/linux/blkdev.h
kernel/trace/blktrace.c

index 05fb27cbb667842a3e40ce4c9a2f456645a27c44..c1763b43f3332c086b34f0336b86b1538deeaa9d 100644 (file)
@@ -1048,7 +1048,7 @@ struct block_device *bdget_disk(struct gendisk *disk, int partno)
 
        part = disk_get_part(disk, partno);
        if (part)
-               bdev = bdget(part_devt(part));
+               bdev = bdget_part(part);
        disk_put_part(part);
 
        return bdev;
index dd6811422a87af009636c19249e357395530f160..5309e0f44ba35287ae53343d8733eba773c47ce9 100644 (file)
@@ -580,7 +580,7 @@ int bdev_resize_partition(struct block_device *bdev, int partno,
                return -ENXIO;
 
        ret = -ENOMEM;
-       bdevp = bdget(part_devt(part));
+       bdevp = bdget_part(part);
        if (!bdevp)
                goto out_put_part;
 
index 6b9d19ffa5af7bc437e1a9dc0d00453ef8c4e53f..9e84b1928b9401d0eee5057e5c09e72473e649d0 100644 (file)
@@ -891,7 +891,7 @@ static int bdev_set(struct inode *inode, void *data)
        return 0;
 }
 
-struct block_device *bdget(dev_t dev)
+static struct block_device *bdget(dev_t dev)
 {
        struct block_device *bdev;
        struct inode *inode;
@@ -920,8 +920,6 @@ struct block_device *bdget(dev_t dev)
        return bdev;
 }
 
-EXPORT_SYMBOL(bdget);
-
 /**
  * bdgrab -- Grab a reference to an already referenced block device
  * @bdev:      Block device to grab a reference to.
@@ -933,6 +931,11 @@ struct block_device *bdgrab(struct block_device *bdev)
 }
 EXPORT_SYMBOL(bdgrab);
 
+struct block_device *bdget_part(struct hd_struct *part)
+{
+       return bdget(part_devt(part));
+}
+
 long nr_blockdev_pages(void)
 {
        struct inode *inode;
index a71b096bff246fc08c48b5e72f642609f052eef6..54bb6d7ae2c5c9260fb8decaeb2f94cc3267d0d0 100644 (file)
@@ -1996,7 +1996,7 @@ void bd_abort_claiming(struct block_device *bdev, struct block_device *whole,
 void blkdev_put(struct block_device *bdev, fmode_t mode);
 
 struct block_device *I_BDEV(struct inode *inode);
-struct block_device *bdget(dev_t);
+struct block_device *bdget_part(struct hd_struct *part);
 struct block_device *bdgrab(struct block_device *bdev);
 void bdput(struct block_device *);
 
index ec874ea040922a48317ff588c61f4cab818e17df..f1022945e3460b0bab7dfad8e2cba4333ffb7bc5 100644 (file)
@@ -1827,13 +1827,11 @@ static ssize_t sysfs_blk_trace_attr_show(struct device *dev,
                                         struct device_attribute *attr,
                                         char *buf)
 {
-       struct hd_struct *p = dev_to_part(dev);
+       struct block_device *bdev = bdget_part(dev_to_part(dev));
        struct request_queue *q;
-       struct block_device *bdev;
        struct blk_trace *bt;
        ssize_t ret = -ENXIO;
 
-       bdev = bdget(part_devt(p));
        if (bdev == NULL)
                goto out;
 
@@ -1875,7 +1873,6 @@ static ssize_t sysfs_blk_trace_attr_store(struct device *dev,
 {
        struct block_device *bdev;
        struct request_queue *q;
-       struct hd_struct *p;
        struct blk_trace *bt;
        u64 value;
        ssize_t ret = -EINVAL;
@@ -1895,9 +1892,7 @@ static ssize_t sysfs_blk_trace_attr_store(struct device *dev,
                goto out;
 
        ret = -ENXIO;
-
-       p = dev_to_part(dev);
-       bdev = bdget(part_devt(p));
+       bdev = bdget_part(dev_to_part(dev));
        if (bdev == NULL)
                goto out;