From: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
To: Logan Gunthorpe <logang@deltatee.com>
Cc: linux-kernel@vger.kernel.org, linux-nvme@lists.infradead.org,
linux-block@vger.kernel.org, linux-fsdevel@vger.kernel.org,
Christoph Hellwig <hch@lst.de>, Sagi Grimberg <sagi@grimberg.me>,
Keith Busch <kbusch@kernel.org>, Jens Axboe <axboe@fb.com>,
Chaitanya Kulkarni <Chaitanya.Kulkarni@wdc.com>,
Max Gurtovoy <maxg@mellanox.com>,
Stephen Bates <sbates@raithlin.com>,
Alexander Viro <viro@zeniv.linux.org.uk>
Subject: Re: [PATCH v6 02/16] chardev: introduce cdev_get_by_path()
Date: Thu, 25 Jul 2019 20:27:01 +0200 [thread overview]
Message-ID: <20190725182701.GA11547@kroah.com> (raw)
In-Reply-To: <da0eacb7-3738-ddf3-8c61-7ffc61aa41f4@deltatee.com>
On Thu, Jul 25, 2019 at 12:14:33PM -0600, Logan Gunthorpe wrote:
>
>
> On 2019-07-25 12:08 p.m., Greg Kroah-Hartman wrote:
> > On Thu, Jul 25, 2019 at 11:53:20AM -0600, Logan Gunthorpe wrote:
> >>
> >>
> >> On 2019-07-25 11:40 a.m., Greg Kroah-Hartman wrote:
> >>> On Thu, Jul 25, 2019 at 11:23:21AM -0600, Logan Gunthorpe wrote:
> >>>> cdev_get_by_path() attempts to retrieve a struct cdev from
> >>>> a path name. It is analagous to blkdev_get_by_path().
> >>>>
> >>>> This will be necessary to create a nvme_ctrl_get_by_path()to
> >>>> support NVMe-OF passthru.
> >>>
> >>> Ick, why? Why would a cdev have a "pathname"?
> >>
> >> So we can go from "/dev/nvme0" (which points to a char device) to its
> >> struct cdev and eventually it's struct nvme_ctrl. Doing it this way also
> >> allows supporting symlinks that might be created by udev rules.
> >
> > Why do you have a "string" within the kernel and are not using the
> > normal open() call from userspace on the character device node on the
> > filesystem in your namespace/mount/whatever?
>
> NVMe-OF is configured using configfs. The target is specified by the
> user writing a path to a configfs attribute. This is the way it works
> today but with blkdev_get_by_path()[1]. For the passthru code, we need
> to get a nvme_ctrl instead of a block_device, but the principal is the same.
Why isn't a fd being passed in there instead of a random string?
Seems odd, but oh well, that ship sailed a long time ago for block
devices I guess.
So what do you actually _do_ with that char device once you have it?
greg k-h
WARNING: multiple messages have this Message-ID (diff)
From: gregkh@linuxfoundation.org (Greg Kroah-Hartman)
Subject: [PATCH v6 02/16] chardev: introduce cdev_get_by_path()
Date: Thu, 25 Jul 2019 20:27:01 +0200 [thread overview]
Message-ID: <20190725182701.GA11547@kroah.com> (raw)
In-Reply-To: <da0eacb7-3738-ddf3-8c61-7ffc61aa41f4@deltatee.com>
On Thu, Jul 25, 2019@12:14:33PM -0600, Logan Gunthorpe wrote:
>
>
> On 2019-07-25 12:08 p.m., Greg Kroah-Hartman wrote:
> > On Thu, Jul 25, 2019@11:53:20AM -0600, Logan Gunthorpe wrote:
> >>
> >>
> >> On 2019-07-25 11:40 a.m., Greg Kroah-Hartman wrote:
> >>> On Thu, Jul 25, 2019@11:23:21AM -0600, Logan Gunthorpe wrote:
> >>>> cdev_get_by_path() attempts to retrieve a struct cdev from
> >>>> a path name. It is analagous to blkdev_get_by_path().
> >>>>
> >>>> This will be necessary to create a nvme_ctrl_get_by_path()to
> >>>> support NVMe-OF passthru.
> >>>
> >>> Ick, why? Why would a cdev have a "pathname"?
> >>
> >> So we can go from "/dev/nvme0" (which points to a char device) to its
> >> struct cdev and eventually it's struct nvme_ctrl. Doing it this way also
> >> allows supporting symlinks that might be created by udev rules.
> >
> > Why do you have a "string" within the kernel and are not using the
> > normal open() call from userspace on the character device node on the
> > filesystem in your namespace/mount/whatever?
>
> NVMe-OF is configured using configfs. The target is specified by the
> user writing a path to a configfs attribute. This is the way it works
> today but with blkdev_get_by_path()[1]. For the passthru code, we need
> to get a nvme_ctrl instead of a block_device, but the principal is the same.
Why isn't a fd being passed in there instead of a random string?
Seems odd, but oh well, that ship sailed a long time ago for block
devices I guess.
So what do you actually _do_ with that char device once you have it?
greg k-h
next prev parent reply other threads:[~2019-07-25 18:27 UTC|newest]
Thread overview: 122+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-07-25 17:23 [PATCH v6 00/16] nvmet: add target passthru commands support Logan Gunthorpe
2019-07-25 17:23 ` Logan Gunthorpe
2019-07-25 17:23 ` [PATCH v6 01/16] chardev: factor out cdev_lookup() helper Logan Gunthorpe
2019-07-25 17:23 ` Logan Gunthorpe
2019-07-25 17:23 ` [PATCH v6 02/16] chardev: introduce cdev_get_by_path() Logan Gunthorpe
2019-07-25 17:23 ` Logan Gunthorpe
2019-07-25 17:40 ` Greg Kroah-Hartman
2019-07-25 17:40 ` Greg Kroah-Hartman
2019-07-25 17:53 ` Logan Gunthorpe
2019-07-25 17:53 ` Logan Gunthorpe
2019-07-25 17:58 ` Matthew Wilcox
2019-07-25 17:58 ` Matthew Wilcox
2019-07-25 18:08 ` Logan Gunthorpe
2019-07-25 18:08 ` Logan Gunthorpe
2019-07-25 18:08 ` Greg Kroah-Hartman
2019-07-25 18:08 ` Greg Kroah-Hartman
2019-07-25 18:14 ` Logan Gunthorpe
2019-07-25 18:14 ` Logan Gunthorpe
2019-07-25 18:27 ` Greg Kroah-Hartman [this message]
2019-07-25 18:27 ` Greg Kroah-Hartman
2019-07-25 18:36 ` Logan Gunthorpe
2019-07-25 18:36 ` Logan Gunthorpe
2019-07-25 19:02 ` Sagi Grimberg
2019-07-25 19:02 ` Sagi Grimberg
2019-07-25 19:34 ` Greg Kroah-Hartman
2019-07-25 19:34 ` Greg Kroah-Hartman
2019-07-25 19:37 ` Sagi Grimberg
2019-07-25 19:37 ` Sagi Grimberg
2019-07-25 19:43 ` Greg Kroah-Hartman
2019-07-25 19:43 ` Greg Kroah-Hartman
2019-07-25 19:45 ` Sagi Grimberg
2019-07-25 19:45 ` Sagi Grimberg
2019-07-25 19:43 ` Sagi Grimberg
2019-07-25 19:43 ` Sagi Grimberg
2019-07-25 19:41 ` Logan Gunthorpe
2019-07-25 19:41 ` Logan Gunthorpe
2019-07-25 19:00 ` Matthew Wilcox
2019-07-25 19:00 ` Matthew Wilcox
2019-07-25 19:05 ` Sagi Grimberg
2019-07-25 19:05 ` Sagi Grimberg
2019-07-25 19:11 ` Matthew Wilcox
2019-07-25 19:11 ` Matthew Wilcox
2019-07-25 19:24 ` Logan Gunthorpe
2019-07-25 19:24 ` Logan Gunthorpe
2019-07-25 19:26 ` Matthew Wilcox
2019-07-25 19:26 ` Matthew Wilcox
2019-07-25 19:31 ` Logan Gunthorpe
2019-07-25 19:31 ` Logan Gunthorpe
2019-07-25 23:55 ` Al Viro
2019-07-25 23:55 ` Al Viro
2019-07-26 4:29 ` Sagi Grimberg
2019-07-26 4:29 ` Sagi Grimberg
2019-07-26 7:13 ` Greg Kroah-Hartman
2019-07-26 7:13 ` Greg Kroah-Hartman
2019-07-26 15:46 ` Logan Gunthorpe
2019-07-26 15:46 ` Logan Gunthorpe
2019-07-25 19:31 ` Sagi Grimberg
2019-07-25 19:31 ` Sagi Grimberg
2019-07-25 18:10 ` Greg Kroah-Hartman
2019-07-25 18:10 ` Greg Kroah-Hartman
2019-07-25 18:16 ` Logan Gunthorpe
2019-07-25 18:16 ` Logan Gunthorpe
2019-07-25 17:23 ` [PATCH v6 03/16] chardev: export cdev_put() Logan Gunthorpe
2019-07-25 17:23 ` Logan Gunthorpe
2019-07-25 17:23 ` [PATCH v6 04/16] nvme-core: introduce nvme_get_by_path() Logan Gunthorpe
2019-07-25 17:23 ` Logan Gunthorpe
2019-07-25 17:50 ` Matthew Wilcox
2019-07-25 17:50 ` Matthew Wilcox
2019-07-25 17:54 ` Logan Gunthorpe
2019-07-25 17:54 ` Logan Gunthorpe
2019-07-25 19:58 ` Keith Busch
2019-07-25 19:58 ` Keith Busch
2019-07-25 20:12 ` Sagi Grimberg
2019-07-25 20:12 ` Sagi Grimberg
2019-07-25 20:28 ` Logan Gunthorpe
2019-07-25 20:28 ` Logan Gunthorpe
2019-07-25 20:31 ` Keith Busch
2019-07-25 20:31 ` Keith Busch
2019-07-25 20:37 ` Logan Gunthorpe
2019-07-25 20:37 ` Logan Gunthorpe
2019-07-25 17:23 ` [PATCH v6 05/16] nvme-core: export existing ctrl and ns interfaces Logan Gunthorpe
2019-07-25 17:23 ` Logan Gunthorpe
2019-07-25 17:23 ` [PATCH v6 06/16] nvmet: add return value to nvmet_add_async_event() Logan Gunthorpe
2019-07-25 17:23 ` Logan Gunthorpe
2019-07-25 17:23 ` [PATCH v6 07/16] nvmet: make nvmet_copy_ns_identifier() non-static Logan Gunthorpe
2019-07-25 17:23 ` Logan Gunthorpe
2019-07-25 17:23 ` [PATCH v6 08/16] nvmet-passthru: update KConfig with config passthru option Logan Gunthorpe
2019-07-25 17:23 ` Logan Gunthorpe
2019-07-25 17:23 ` [PATCH v6 09/16] nvmet-passthru: add passthru code to process commands Logan Gunthorpe
2019-07-25 17:23 ` Logan Gunthorpe
2019-07-25 17:23 ` [PATCH v6 10/16] nvmet-passthru: add enable/disable helpers Logan Gunthorpe
2019-07-25 17:23 ` Logan Gunthorpe
2019-07-25 17:23 ` [PATCH v6 11/16] nvmet-core: allow one host per passthru-ctrl Logan Gunthorpe
2019-07-25 17:23 ` Logan Gunthorpe
2019-07-25 17:23 ` [PATCH v6 12/16] nvmet-core: don't check the data len for pt-ctrl Logan Gunthorpe
2019-07-25 17:23 ` Logan Gunthorpe
2019-07-25 17:23 ` [PATCH v6 13/16] nvmet-configfs: introduce passthru configfs interface Logan Gunthorpe
2019-07-25 17:23 ` Logan Gunthorpe
2019-07-25 17:23 ` [PATCH v6 14/16] block: don't check blk_rq_is_passthrough() in blk_do_io_stat() Logan Gunthorpe
2019-07-25 17:23 ` Logan Gunthorpe
2019-07-25 17:23 ` [PATCH v6 15/16] block: call blk_account_io_start() in blk_execute_rq_nowait() Logan Gunthorpe
2019-07-25 17:23 ` Logan Gunthorpe
2019-07-25 17:23 ` [PATCH v6 16/16] nvmet-passthru: support block accounting Logan Gunthorpe
2019-07-25 17:23 ` Logan Gunthorpe
2019-07-26 6:23 ` [PATCH v6 00/16] nvmet: add target passthru commands support Hannes Reinecke
2019-07-26 6:23 ` Hannes Reinecke
2019-07-26 17:07 ` Logan Gunthorpe
2019-07-26 17:07 ` Logan Gunthorpe
2019-07-26 22:21 ` Sagi Grimberg
2019-07-26 22:21 ` Sagi Grimberg
2019-07-26 22:37 ` Logan Gunthorpe
2019-07-26 22:37 ` Logan Gunthorpe
2019-07-26 23:13 ` Sagi Grimberg
2019-07-26 23:13 ` Sagi Grimberg
2019-07-27 0:09 ` Logan Gunthorpe
2019-07-27 0:09 ` Logan Gunthorpe
2019-07-27 0:50 ` Stephen Bates
2019-07-27 0:50 ` Stephen Bates
2019-07-29 16:15 ` Sagi Grimberg
2019-07-29 16:15 ` Sagi Grimberg
2019-07-29 16:17 ` Logan Gunthorpe
2019-07-29 16:17 ` Logan Gunthorpe
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20190725182701.GA11547@kroah.com \
--to=gregkh@linuxfoundation.org \
--cc=Chaitanya.Kulkarni@wdc.com \
--cc=axboe@fb.com \
--cc=hch@lst.de \
--cc=kbusch@kernel.org \
--cc=linux-block@vger.kernel.org \
--cc=linux-fsdevel@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-nvme@lists.infradead.org \
--cc=logang@deltatee.com \
--cc=maxg@mellanox.com \
--cc=sagi@grimberg.me \
--cc=sbates@raithlin.com \
--cc=viro@zeniv.linux.org.uk \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.