Message ID | 20220622135822.3564952-1-hch@lst.de (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Series | nfs/blocklayout: refactor block device opening | expand |
ping? On Wed, Jun 22, 2022 at 03:58:22PM +0200, Christoph Hellwig wrote: > Deduplicate the helpers to open a device node by passing a name > prefix argument and using the same helper for both kinds of paths. > > Signed-off-by: Christoph Hellwig <hch@lst.de> > --- > fs/nfs/blocklayout/dev.c | 42 +++++++++++----------------------------- > 1 file changed, 11 insertions(+), 31 deletions(-) > > diff --git a/fs/nfs/blocklayout/dev.c b/fs/nfs/blocklayout/dev.c > index 5e56da748b2ab..fea5f8821da5e 100644 > --- a/fs/nfs/blocklayout/dev.c > +++ b/fs/nfs/blocklayout/dev.c > @@ -301,18 +301,14 @@ bl_validate_designator(struct pnfs_block_volume *v) > } > } > > -/* > - * Try to open the udev path for the WWN. At least on Debian the udev > - * by-id path will always point to the dm-multipath device if one exists. > - */ > static struct block_device * > -bl_open_udev_path(struct pnfs_block_volume *v) > +bl_open_path(struct pnfs_block_volume *v, const char *prefix) > { > struct block_device *bdev; > const char *devname; > > - devname = kasprintf(GFP_KERNEL, "/dev/disk/by-id/wwn-0x%*phN", > - v->scsi.designator_len, v->scsi.designator); > + devname = kasprintf(GFP_KERNEL, "/dev/disk/by-id/%s%*phN", > + prefix, v->scsi.designator_len, v->scsi.designator); > if (!devname) > return ERR_PTR(-ENOMEM); > > @@ -326,28 +322,6 @@ bl_open_udev_path(struct pnfs_block_volume *v) > return bdev; > } > > -/* > - * Try to open the RH/Fedora specific dm-mpath udev path for this WWN, as the > - * wwn- links will only point to the first discovered SCSI device there. > - */ > -static struct block_device * > -bl_open_dm_mpath_udev_path(struct pnfs_block_volume *v) > -{ > - struct block_device *bdev; > - const char *devname; > - > - devname = kasprintf(GFP_KERNEL, > - "/dev/disk/by-id/dm-uuid-mpath-%d%*phN", > - v->scsi.designator_type, > - v->scsi.designator_len, v->scsi.designator); > - if (!devname) > - return ERR_PTR(-ENOMEM); > - > - bdev = blkdev_get_by_path(devname, FMODE_READ | FMODE_WRITE, NULL); > - kfree(devname); > - return bdev; > -} > - > static int > bl_parse_scsi(struct nfs_server *server, struct pnfs_block_dev *d, > struct pnfs_block_volume *volumes, int idx, gfp_t gfp_mask) > @@ -360,9 +334,15 @@ bl_parse_scsi(struct nfs_server *server, struct pnfs_block_dev *d, > if (!bl_validate_designator(v)) > return -EINVAL; > > - bdev = bl_open_dm_mpath_udev_path(v); > + /* > + * Try to open the RH/Fedora specific dm-mpath udev path first, as the > + * wwn- links will only point to the first discovered SCSI device there. > + * On other distributions like Debian, the default SCSI by-id path will > + * point to the dm-multipath device if one exists. > + */ > + bdev = bl_open_path(v, "dm-uuid-mpath-0x"); > if (IS_ERR(bdev)) > - bdev = bl_open_udev_path(v); > + bdev = bl_open_path(v, "wwn-0x"); > if (IS_ERR(bdev)) > return PTR_ERR(bdev); > d->bdev = bdev; > -- > 2.30.2 ---end quoted text---
On Tue, 2022-07-26 at 21:21 +0200, Christoph Hellwig wrote: > ping? Queued for the next merge window, and should already be appearing in linux-next. > > On Wed, Jun 22, 2022 at 03:58:22PM +0200, Christoph Hellwig wrote: > > Deduplicate the helpers to open a device node by passing a name > > prefix argument and using the same helper for both kinds of paths. > > > > Signed-off-by: Christoph Hellwig <hch@lst.de> > > --- > > fs/nfs/blocklayout/dev.c | 42 +++++++++++------------------------- > > ---- > > 1 file changed, 11 insertions(+), 31 deletions(-) > > > > diff --git a/fs/nfs/blocklayout/dev.c b/fs/nfs/blocklayout/dev.c > > index 5e56da748b2ab..fea5f8821da5e 100644 > > --- a/fs/nfs/blocklayout/dev.c > > +++ b/fs/nfs/blocklayout/dev.c > > @@ -301,18 +301,14 @@ bl_validate_designator(struct > > pnfs_block_volume *v) > > } > > } > > > > -/* > > - * Try to open the udev path for the WWN. At least on Debian the > > udev > > - * by-id path will always point to the dm-multipath device if one > > exists. > > - */ > > static struct block_device * > > -bl_open_udev_path(struct pnfs_block_volume *v) > > +bl_open_path(struct pnfs_block_volume *v, const char *prefix) > > { > > struct block_device *bdev; > > const char *devname; > > > > - devname = kasprintf(GFP_KERNEL, "/dev/disk/by-id/wwn- > > 0x%*phN", > > - v->scsi.designator_len, v- > > >scsi.designator); > > + devname = kasprintf(GFP_KERNEL, "/dev/disk/by-id/%s%*phN", > > + prefix, v->scsi.designator_len, v- > > >scsi.designator); > > if (!devname) > > return ERR_PTR(-ENOMEM); > > > > @@ -326,28 +322,6 @@ bl_open_udev_path(struct pnfs_block_volume *v) > > return bdev; > > } > > > > -/* > > - * Try to open the RH/Fedora specific dm-mpath udev path for this > > WWN, as the > > - * wwn- links will only point to the first discovered SCSI device > > there. > > - */ > > -static struct block_device * > > -bl_open_dm_mpath_udev_path(struct pnfs_block_volume *v) > > -{ > > - struct block_device *bdev; > > - const char *devname; > > - > > - devname = kasprintf(GFP_KERNEL, > > - "/dev/disk/by-id/dm-uuid-mpath-%d%*phN", > > - v->scsi.designator_type, > > - v->scsi.designator_len, v- > > >scsi.designator); > > - if (!devname) > > - return ERR_PTR(-ENOMEM); > > - > > - bdev = blkdev_get_by_path(devname, FMODE_READ | > > FMODE_WRITE, NULL); > > - kfree(devname); > > - return bdev; > > -} > > - > > static int > > bl_parse_scsi(struct nfs_server *server, struct pnfs_block_dev *d, > > struct pnfs_block_volume *volumes, int idx, gfp_t > > gfp_mask) > > @@ -360,9 +334,15 @@ bl_parse_scsi(struct nfs_server *server, > > struct pnfs_block_dev *d, > > if (!bl_validate_designator(v)) > > return -EINVAL; > > > > - bdev = bl_open_dm_mpath_udev_path(v); > > + /* > > + * Try to open the RH/Fedora specific dm-mpath udev path > > first, as the > > + * wwn- links will only point to the first discovered SCSI > > device there. > > + * On other distributions like Debian, the default SCSI by- > > id path will > > + * point to the dm-multipath device if one exists. > > + */ > > + bdev = bl_open_path(v, "dm-uuid-mpath-0x"); > > if (IS_ERR(bdev)) > > - bdev = bl_open_udev_path(v); > > + bdev = bl_open_path(v, "wwn-0x"); > > if (IS_ERR(bdev)) > > return PTR_ERR(bdev); > > d->bdev = bdev; > > -- > > 2.30.2 > ---end quoted text---
diff --git a/fs/nfs/blocklayout/dev.c b/fs/nfs/blocklayout/dev.c index 5e56da748b2ab..fea5f8821da5e 100644 --- a/fs/nfs/blocklayout/dev.c +++ b/fs/nfs/blocklayout/dev.c @@ -301,18 +301,14 @@ bl_validate_designator(struct pnfs_block_volume *v) } } -/* - * Try to open the udev path for the WWN. At least on Debian the udev - * by-id path will always point to the dm-multipath device if one exists. - */ static struct block_device * -bl_open_udev_path(struct pnfs_block_volume *v) +bl_open_path(struct pnfs_block_volume *v, const char *prefix) { struct block_device *bdev; const char *devname; - devname = kasprintf(GFP_KERNEL, "/dev/disk/by-id/wwn-0x%*phN", - v->scsi.designator_len, v->scsi.designator); + devname = kasprintf(GFP_KERNEL, "/dev/disk/by-id/%s%*phN", + prefix, v->scsi.designator_len, v->scsi.designator); if (!devname) return ERR_PTR(-ENOMEM); @@ -326,28 +322,6 @@ bl_open_udev_path(struct pnfs_block_volume *v) return bdev; } -/* - * Try to open the RH/Fedora specific dm-mpath udev path for this WWN, as the - * wwn- links will only point to the first discovered SCSI device there. - */ -static struct block_device * -bl_open_dm_mpath_udev_path(struct pnfs_block_volume *v) -{ - struct block_device *bdev; - const char *devname; - - devname = kasprintf(GFP_KERNEL, - "/dev/disk/by-id/dm-uuid-mpath-%d%*phN", - v->scsi.designator_type, - v->scsi.designator_len, v->scsi.designator); - if (!devname) - return ERR_PTR(-ENOMEM); - - bdev = blkdev_get_by_path(devname, FMODE_READ | FMODE_WRITE, NULL); - kfree(devname); - return bdev; -} - static int bl_parse_scsi(struct nfs_server *server, struct pnfs_block_dev *d, struct pnfs_block_volume *volumes, int idx, gfp_t gfp_mask) @@ -360,9 +334,15 @@ bl_parse_scsi(struct nfs_server *server, struct pnfs_block_dev *d, if (!bl_validate_designator(v)) return -EINVAL; - bdev = bl_open_dm_mpath_udev_path(v); + /* + * Try to open the RH/Fedora specific dm-mpath udev path first, as the + * wwn- links will only point to the first discovered SCSI device there. + * On other distributions like Debian, the default SCSI by-id path will + * point to the dm-multipath device if one exists. + */ + bdev = bl_open_path(v, "dm-uuid-mpath-0x"); if (IS_ERR(bdev)) - bdev = bl_open_udev_path(v); + bdev = bl_open_path(v, "wwn-0x"); if (IS_ERR(bdev)) return PTR_ERR(bdev); d->bdev = bdev;
Deduplicate the helpers to open a device node by passing a name prefix argument and using the same helper for both kinds of paths. Signed-off-by: Christoph Hellwig <hch@lst.de> --- fs/nfs/blocklayout/dev.c | 42 +++++++++++----------------------------- 1 file changed, 11 insertions(+), 31 deletions(-)