From: David Disseldorp <ddiss@suse.de>
To: Roman Bolshakov <r.bolshakov@yadro.com>
Cc: Sergey Samoylenko <s.samoylenko@yadro.com>,
<martin.petersen@oracle.com>, <michael.christie@oracle.com>,
<bvanassche@acm.org>, <target-devel@vger.kernel.org>,
<linux-scsi@vger.kernel.org>, <linux@yadro.com>,
Konstantin Shelekhin <k.shelekhin@yadro.com>,
Dmitry Bogdanov <d.bogdanov@yadro.com>,
Anastasia Kovaleva <a.kovaleva@yadro.com>
Subject: Re: [PATCH 1/1] scsi: target: core: Add 8Fh VPD page
Date: Tue, 17 Aug 2021 00:00:35 +0200 [thread overview]
Message-ID: <20210817000035.7a514c50@suse.de> (raw)
In-Reply-To: <YRqq50h81kYFFHki@SPB-NB-133.local>
On Mon, 16 Aug 2021 21:13:59 +0300, Roman Bolshakov wrote:
> On Fri, Aug 13, 2021 at 04:52:55PM +0200, David Disseldorp wrote:
> > Hi Sergey,
> >
> > On Thu, 29 Jul 2021 23:19:43 +0300, Sergey Samoylenko wrote:
> >
> > > The 8Fh VPD page announces the capabilities supported by
> > > the TCM XCOPY manager. It helps to expand the coverage of
> > > the third-party copy manager with SCSI testing utilities.
> >
> > Please list which initiators use this VPD page, if you know of any.
> > Also, is there any test coverage for this? I don't see anything in
> > libiscsi...
> >
>
> Hi David,
>
> ESXi is one of the hosts that inspects Third Party Copy VPD Page.
> Windows detects ODX support using the page [1][2].
Thanks for the links. I haven't seen ESXi attempt to use it, but also
haven't checked for some time. It'd be good to get some of this
information in the commit message.
> The page is also used by libiscsi to detect presence and features of
> copy manager as was agreed with Bart in the PR [3]:
I'm probably missing something, but why wasn't the 3PC flag in the
standard inquiry page an option for this check?
> "Implementing REPORT SUPPORTED OPERATION CODES in LIO would require more
> work than implementing the third-party copy VPD page.
>
> I'm fine with relying on the third-party copy VPD page, or in other
> words, to skip the copy offloading tests if that page is not supported.
>
> There are plans to implement XCOPY support in the Linux kernel sd
> driver. If nobody else volunteers I plan to work on this myself. I'm
> considering to only support SCSI targets that support the third-party
> copy VPD page. Or in other words, we will need support for that VPD page
> anyway."
Okay, fair enough.
>
> 1. https://www.slideshare.net/CalvinChen5/a-joint-effort-of-the-storage-industry
> 2. http://sg.danny.cz/sg/ddpt_xcopy_odx.html
> 3. https://github.com/sahlberg/libiscsi/pull/353
>
> > > Reviewed-by: Konstantin Shelekhin <k.shelekhin@yadro.com>
> > > Reviewed-by: Dmitry Bogdanov <d.bogdanov@yadro.com>
> > > Reviewed-by: Anastasia Kovaleva <a.kovaleva@yadro.com>
> > > Signed-off-by: Sergey Samoylenko <s.samoylenko@yadro.com>
> > > ---
> > > drivers/target/target_core_spc.c | 230 ++++++++++++++++++++++++++++++-
> > > 1 file changed, 226 insertions(+), 4 deletions(-)
> > >
> > > diff --git a/drivers/target/target_core_spc.c b/drivers/target/target_core_spc.c
> > > index 22703a0dbd07..169341712b10 100644
> > > --- a/drivers/target/target_core_spc.c
> > > +++ b/drivers/target/target_core_spc.c
> > ...
> > > +/* Third-party Copy VPD page */
> > > +static sense_reason_t
> > > +spc_emulate_evpd_8f(struct se_cmd *cmd, unsigned char *buf)
> > > +{
> > > + struct se_device *dev = cmd->se_dev;
> > > + int off;
> > > + u16 page_len;
> > > +
> > > + if (!dev->dev_attrib.emulate_3pc)
> > > + return TCM_INVALID_CDB_FIELD;
> > > +
> > > + /*
> > > + * Since the Third-party copy manager in TCM is quite simple
> > > + * and supports only two commands, the function sets
> > > + * many descriptor parameters as constants.
> > > + *
> > > + * As the Copy manager supports the EXTENDED COPY(LID1) command,
> > > + * the Third-party Copy VPD page should include five mandatory
> > > + * Third-party copy descriptors. Its are:
> > > + * 0001h - Supported Commands
> > > + * 0004h - Parameter Data
> > > + * 0008h - Supported Descriptors
> > > + * 000Ch - Supported CSCD Descriptor IDs
> > > + * 8001h - General Copy Operations
> > > + *
> > > + * See spc4 section 7.8.17
> > > + */
> > > +
> > > + off = 4;
> > > +
> > > + /* fill descriptors */
> > > + off += spc_evpd_8f_encode_supp_cmds(&buf[off]);
> > > + off += spc_evpd_8f_encode_param_data(&buf[off]);
> > > + off += spc_evpd_8f_encode_supp_descrs(&buf[off]);
> > > + off += spc_evpd_8f_encode_supp_cscd_descr_id(&buf[off]);
> > > + off += spc_evpd_8f_encode_general_copy_ops(&buf[off]);
> >
> > This looks risky in terms of buf overrun. I think it'd be good to pass
> > a @remaining or @buf_end param to these helper functions.
> >
>
> It's doable but would require to change the signature of all existing
> VPD handlers. SE_INQUIRY_BUF is hardcoded to 1kb but it's also capped by
> EDTL to avoid buffer overruns:
>
> memcpy(rbuf, buf, min_t(u32, SE_INQUIRY_BUF, cmd->data_length));
That's checking the amount copied into the response buffer. My concern
is the prior writes to the staging buf.
Cheers, David
next prev parent reply other threads:[~2021-08-16 22:00 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-07-29 20:19 [PATCH 0/1] scsi: target: core: Add 8Fh VPD page Sergey Samoylenko
2021-07-29 20:19 ` [PATCH 1/1] " Sergey Samoylenko
2021-08-13 14:52 ` David Disseldorp
2021-08-16 18:13 ` Roman Bolshakov
2021-08-16 22:00 ` David Disseldorp [this message]
2021-08-16 18:16 ` Sergey Samoylenko
2021-08-16 22:48 ` David Disseldorp
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=20210817000035.7a514c50@suse.de \
--to=ddiss@suse.de \
--cc=a.kovaleva@yadro.com \
--cc=bvanassche@acm.org \
--cc=d.bogdanov@yadro.com \
--cc=k.shelekhin@yadro.com \
--cc=linux-scsi@vger.kernel.org \
--cc=linux@yadro.com \
--cc=martin.petersen@oracle.com \
--cc=michael.christie@oracle.com \
--cc=r.bolshakov@yadro.com \
--cc=s.samoylenko@yadro.com \
--cc=target-devel@vger.kernel.org \
/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.