linux-rdma.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Leon Romanovsky <leon-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
To: Adit Ranadive <aditr-pghWNbHTmq7QT0dZR+AlfA@public.gmane.org>
Cc: Yuval Shaia <yuval.shaia-QHcLZuEGTsvQT0dZR+AlfA@public.gmane.org>,
	"dledford-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org"
	<dledford-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>,
	"linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org"
	<linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org>,
	"pv-drivers-pghWNbHTmq7QT0dZR+AlfA@public.gmane.org"
	<pv-drivers-pghWNbHTmq7QT0dZR+AlfA@public.gmane.org>,
	"Jorgen S. Hansen"
	<jhansen-pghWNbHTmq7QT0dZR+AlfA@public.gmane.org>,
	Aditya Sarwade <asarwade-pghWNbHTmq7QT0dZR+AlfA@public.gmane.org>,
	George Zhang
	<georgezhang-pghWNbHTmq7QT0dZR+AlfA@public.gmane.org>,
	Bryan Tan <bryantan-pghWNbHTmq7QT0dZR+AlfA@public.gmane.org>
Subject: Re: [PATCH v2 02/15] IB/pvrdma: Add device command support
Date: Sun, 31 Jul 2016 09:15:47 +0300	[thread overview]
Message-ID: <20160731061547.GV4628@leon.nu> (raw)
In-Reply-To: <BLUPR0501MB8364D3CE8FF7DE654D1E045C5010-84Rf5TRaNBMVDhIuTCx1aJLWcSx1hRipwIZJ9u9yWa8oOQlpcoRfSA@public.gmane.org>

[-- Attachment #1: Type: text/plain, Size: 2448 bytes --]

On Fri, Jul 29, 2016 at 09:31:16PM +0000, Adit Ranadive wrote:
> On Fri, 29 Jul 2016 12:37:29 +0000, Leon Romanovsky <leon-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org> wrote:
> > On Thu, Jul 28, 2016 at 10:51:39PM +0000, Adit Ranadive wrote:
> > > On Mon, 18 Jul 2016 15:46:53 +0300 Yuval Shaia <yuval.shaia-QHcLZuEGTsthl2p70BpVqQ@public.gmane.orgm> wrote:
> > > > On Tue, Jul 12, 2016 at 12:36:32PM -0700, Adit Ranadive wrote:
> > > > > This patch enables posting Verb requests and receiving responses to/from
> > > > > the backend PVRDMA emulation layer.
> > > > >
> > >
> > > ...
> > >
> > > > > +int
> > > > > +pvrdma_cmd_post(struct pvrdma_dev *dev, union pvrdma_cmd_req *req,
> > > > > +		bool expect_resp, union pvrdma_cmd_resp *resp)
> > > > > +{
> > > > > +	int err;
> > > > > +
> > > > > +	dev_dbg(&dev->pdev->dev, "post request to device\n");
> > > > > +
> > > > > +	/* Serializiation */
> > > > > +	down(&dev->cmd_sema);
> > > > > +
> > > > > +	spin_lock(&dev->cmd_lock);
> > > > > +	memcpy(dev->cmd_slot, req, sizeof(*req));
> > > >
> > > > Just to protect against memory corruption suggesting to do:
> > > > 	memcpy(dev->cmd_slot, req, min(PAGE_SIZE, sizeof(*req)));
> > > >
> > >
> > > Done.
> > 
> > Hi Adit,
> > I didn't check how "dev->cmd_slot" was declared and if it is equal to
> > req in size. Additionally I didn't check if memcpy has any size
> > limitations, but wanted to warn you that implementation of this
> > suggestion as is will leave your system in much worse situation of
> > partially copied data.
> > 
> > if you really want to check sizes, please do it with BUILD_ON compilation
> > macro. I have serious doubts if you need it.
> > 
> > Thanks
> 
> Hi Leon,
> 
> Thanks for taking a look!
> I think this is okay to do was that we allocate a page for cmd_slot anyways
> and the size of req will always be smaller than PAGE_SIZE. If the request is
> malformed, our virtual hardware should throw an error for it.
> I dont think we would run into partially copied data.
> 
> Having said that, I dont see a necessary advantage of using min here so am
> willing to drop it if you feel strongly about it.
> 
> Can you clarify what you mean by memcpy size limitations?

I didn't have time to look after reasons for Yuval's comment about
min(..), so I assumed that one of the possibilities will be limitation
of memcpy which I'm not aware.

> 
> Thanks,
> Adit

[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 819 bytes --]

  parent reply	other threads:[~2016-07-31  6:15 UTC|newest]

Thread overview: 45+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2016-07-12 19:36 [PATCH v2 00/15] Add Paravirtual RDMA Driver Adit Ranadive
     [not found] ` <1468352205-9137-1-git-send-email-aditr-pghWNbHTmq7QT0dZR+AlfA@public.gmane.org>
2016-07-12 19:36   ` [PATCH v2 01/15] IB/pvrdma: Add paravirtual rdma device Adit Ranadive
     [not found]     ` <1468352205-9137-2-git-send-email-aditr-pghWNbHTmq7QT0dZR+AlfA@public.gmane.org>
2016-07-18 12:27       ` Yuval Shaia
     [not found]         ` <20160718122738.GD6165-Hxa29pjIrETlQW142y8m19+IiqhCXseY@public.gmane.org>
2016-07-22  0:11           ` Adit Ranadive
2016-07-26  5:38       ` Leon Romanovsky
     [not found]         ` <20160726053820.GE20674-2ukJVAZIZ/Y@public.gmane.org>
2016-07-28 20:56           ` Adit Ranadive
2016-07-12 19:36   ` [PATCH v2 02/15] IB/pvrdma: Add device command support Adit Ranadive
     [not found]     ` <1468352205-9137-3-git-send-email-aditr-pghWNbHTmq7QT0dZR+AlfA@public.gmane.org>
2016-07-18 12:46       ` Yuval Shaia
     [not found]         ` <20160718124652.GE6165-Hxa29pjIrETlQW142y8m19+IiqhCXseY@public.gmane.org>
2016-07-28 22:51           ` Adit Ranadive
     [not found]             ` <BLUPR0501MB8363954E94FE9D268E66CB7C5000-84Rf5TRaNBMVDhIuTCx1aJLWcSx1hRipwIZJ9u9yWa8oOQlpcoRfSA@public.gmane.org>
2016-07-29 12:37               ` Leon Romanovsky
     [not found]                 ` <20160729123711.GU4628-2ukJVAZIZ/Y@public.gmane.org>
2016-07-29 21:31                   ` Adit Ranadive
     [not found]                     ` <BLUPR0501MB8364D3CE8FF7DE654D1E045C5010-84Rf5TRaNBMVDhIuTCx1aJLWcSx1hRipwIZJ9u9yWa8oOQlpcoRfSA@public.gmane.org>
2016-07-31  6:15                       ` Leon Romanovsky [this message]
     [not found]                         ` <20160731061547.GV4628-2ukJVAZIZ/Y@public.gmane.org>
2016-08-14 11:25                           ` Yuval Shaia
2016-08-14 17:23                             ` Leon Romanovsky
     [not found]                               ` <20160814172344.GA5548-2ukJVAZIZ/Y@public.gmane.org>
2016-08-16 16:51                                 ` Adit Ranadive
2016-07-18 13:13       ` Yuval Shaia
     [not found]         ` <20160718131354.GF6165-Hxa29pjIrETlQW142y8m19+IiqhCXseY@public.gmane.org>
2016-07-27 21:57           ` Adit Ranadive
2016-07-12 19:36   ` [PATCH v2 03/15] IB/pvrdma: Add support for Completion Queues Adit Ranadive
     [not found]     ` <1468352205-9137-4-git-send-email-aditr-pghWNbHTmq7QT0dZR+AlfA@public.gmane.org>
2016-07-18 14:12       ` Yuval Shaia
     [not found]         ` <20160718141221.GA20068-Hxa29pjIrETlQW142y8m19+IiqhCXseY@public.gmane.org>
2016-07-28 20:32           ` Adit Ranadive
2016-07-12 19:36   ` [PATCH v2 04/15] IB/pvrdma: Add the paravirtual RDMA device specification Adit Ranadive
     [not found]     ` <1468352205-9137-5-git-send-email-aditr-pghWNbHTmq7QT0dZR+AlfA@public.gmane.org>
2016-07-21  8:45       ` Yuval Shaia
     [not found]         ` <20160721084508.GA8661-Hxa29pjIrETlQW142y8m19+IiqhCXseY@public.gmane.org>
2016-07-28 20:17           ` Adit Ranadive
2016-07-12 19:36   ` [PATCH v2 05/15] IB/pvrdma: Add UAR support Adit Ranadive
     [not found]     ` <1468352205-9137-6-git-send-email-aditr-pghWNbHTmq7QT0dZR+AlfA@public.gmane.org>
2016-07-18 13:25       ` Leon Romanovsky
     [not found]         ` <20160718132545.GD20674-2ukJVAZIZ/Y@public.gmane.org>
2016-07-27 17:58           ` Adit Ranadive
2016-07-27 14:06       ` Yuval Shaia
     [not found]         ` <20160727140611.GC3549-Hxa29pjIrETlQW142y8m19+IiqhCXseY@public.gmane.org>
2016-07-28 20:13           ` Adit Ranadive
2016-07-12 19:36   ` [PATCH v2 06/15] IB/pvrdma: Add virtual device RDMA structures Adit Ranadive
     [not found]     ` <1468352205-9137-7-git-send-email-aditr-pghWNbHTmq7QT0dZR+AlfA@public.gmane.org>
2016-07-26  5:46       ` Leon Romanovsky
     [not found]         ` <20160726054629.GF20674-2ukJVAZIZ/Y@public.gmane.org>
2016-07-28 20:07           ` Adit Ranadive
2016-07-12 19:36   ` [PATCH v2 07/15] IB/pvrdma: Add the main driver module for PVRDMA Adit Ranadive
     [not found]     ` <1468352205-9137-8-git-send-email-aditr-pghWNbHTmq7QT0dZR+AlfA@public.gmane.org>
2016-07-20  9:29       ` Yuval Shaia
2016-07-12 19:36   ` [PATCH v2 08/15] IB/pvrdma: Add helper functions Adit Ranadive
2016-07-12 19:36   ` [PATCH v2 09/15] IB/pvrdma: Add support for memory regions Adit Ranadive
2016-07-12 19:36   ` [PATCH v2 10/15] IB/pvrdma: Add Queue Pair support Adit Ranadive
2016-07-12 19:36   ` [PATCH v2 11/15] IB/pvrdma: Add user-level shared functions Adit Ranadive
     [not found]     ` <1468352205-9137-12-git-send-email-aditr-pghWNbHTmq7QT0dZR+AlfA@public.gmane.org>
2016-07-18 13:59       ` Yuval Shaia
     [not found]         ` <20160718135906.GA21176-Hxa29pjIrETlQW142y8m19+IiqhCXseY@public.gmane.org>
2016-07-28 20:11           ` Adit Ranadive
2016-07-12 19:36   ` [PATCH v2 12/15] IB/pvrdma: Add functions for Verbs support Adit Ranadive
2016-07-12 19:36   ` [PATCH v2 13/15] IB/pvrdma: Add Kconfig and Makefile Adit Ranadive
2016-07-12 19:36   ` [PATCH v2 14/15] IB: Add PVRDMA driver Adit Ranadive
2016-07-12 19:36   ` [PATCH v2 15/15] MAINTAINERS: Update for " Adit Ranadive
2016-07-12 19:50   ` [PATCH v2 00/15] Add Paravirtual RDMA Driver Leon Romanovsky
     [not found]     ` <20160712195027.GD10079-2ukJVAZIZ/Y@public.gmane.org>
2016-07-12 20:36       ` Adit Ranadive

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=20160731061547.GV4628@leon.nu \
    --to=leon-dgejt+ai2ygdnm+yrofe0a@public.gmane.org \
    --cc=aditr-pghWNbHTmq7QT0dZR+AlfA@public.gmane.org \
    --cc=asarwade-pghWNbHTmq7QT0dZR+AlfA@public.gmane.org \
    --cc=bryantan-pghWNbHTmq7QT0dZR+AlfA@public.gmane.org \
    --cc=dledford-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org \
    --cc=georgezhang-pghWNbHTmq7QT0dZR+AlfA@public.gmane.org \
    --cc=jhansen-pghWNbHTmq7QT0dZR+AlfA@public.gmane.org \
    --cc=linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    --cc=pv-drivers-pghWNbHTmq7QT0dZR+AlfA@public.gmane.org \
    --cc=yuval.shaia-QHcLZuEGTsvQT0dZR+AlfA@public.gmane.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).