Discussion of the VIRTIO specification
 help / color / mirror / Atom feed
From: "Michael S. Tsirkin" <mst@redhat.com>
To: "Savir, Gil" <gil.savir@intel.com>
Cc: "virtio-comment@lists.oasis-open.org"
	<virtio-comment@lists.oasis-open.org>,
	"Elmaleh, Liron" <liron.elmaleh@intel.com>,
	cunming.liang@intel.com
Subject: Re: [virtio-comment] VirtIO spec issue - Available Buffer Notification Suppression
Date: Mon, 11 Feb 2019 02:02:30 -0500	[thread overview]
Message-ID: <20190211015836-mutt-send-email-mst@kernel.org> (raw)
In-Reply-To: <20190211014709-mutt-send-email-mst@kernel.org>

On Mon, Feb 11, 2019 at 01:58:09AM -0500, Michael S. Tsirkin wrote:
> On Thu, Jan 31, 2019 at 01:16:29PM +0000, Savir, Gil wrote:
> > Hi,
> > 
> >  
> > 
> > If VIRTIO_F_EVENT_IDX feature bit is negotiated, then Available Buffer
> > Notification Suppression mechanism used is avail event (not flags).
> > 
> > The spec (both v1.0 / v1.1-draft) states that the device MAY use this mechanism
> > (Paragraph 2.4.9.2 / 2.6.10.2 respectively).
> > 
> > This statement implies that the device may choose not to use this suppression
> > mechanism (even if VIRTIO_F_EVENT_IDX was negotiated).
> > 
> >  
> > 
> > However – there’s no way for the device to inform the driver that he is not
> > using avail_event.
> > 
> > As consequence, since there will be a default value in avail_event (probably
> > 0x0), then the driver will always assume that it has to send notify “once-per
> > ring”.
> 
> 
> No I think this part is wrong, pls see below.
> 
> 
> > This will render performance futile, or force the device to actively update
> > avail_event.
> > 
> >  
> > 
> > Is there a way for the device to inform the driver that he is not using
> > avail_event (and I missed it)?
> > 
> >  
> > 
> > If yes, than my apologies for wasting your time.
> > 
> > If no, then I suggest one of the following:
> > 
> > ·         Either, to change the “MAY” (referred above) to “MUST”,
> > 
> 
> Thanks for the feedback!
> 
> So we are talking about split queues.
> 
> If avail_event is never set and remains 0, driver will send
> notifications every time index wraps around to 0, which
> would be every 2^16.
> 
> This is I think expected since the spec says:
> 
> The device MUST handle spurious notifications from the driver.
> 
> 2^16 does not seem excessive so I don't think it will render performance
> futile.


To add to that, above is based on

2.6.10.1
Driver Requirements: Available Buffer Notification Suppression

which states:

After the driver writes a descriptor index into the available ring:
– If the idx field in the available ring (which determined where that descriptor index was placed)
was equal to avail_event, the driver MUST send a notification.
– Otherwise the driver SHOULD NOT send a notification.



Pls let the TC know whether taking the above into account you think
further clarification in the spec is necessary.

Thanks!


> > ·        Or, to add way for the device to inform the driver that he is not
> > using avail_event (flag /certain reserved value in avail_event /other
> > mechanism).
> > 
> >  
> > 
> > Thanks,
> > 
> > Gil Savir
> > 
> > Intel Corporation
> 
> It might be a good addition to spec, probably along the lines
> of an option to send notifications on
> even suppression changes (which was proposed in the past, but
> was not included due to lack of time).
> 
> -- 
> MST

This publicly archived list offers a means to provide input to the
OASIS Virtual I/O Device (VIRTIO) TC.

In order to verify user consent to the Feedback License terms and
to minimize spam in the list archive, subscription is required
before posting.

Subscribe: virtio-comment-subscribe@lists.oasis-open.org
Unsubscribe: virtio-comment-unsubscribe@lists.oasis-open.org
List help: virtio-comment-help@lists.oasis-open.org
List archive: https://lists.oasis-open.org/archives/virtio-comment/
Feedback License: https://www.oasis-open.org/who/ipr/feedback_license.pdf
List Guidelines: https://www.oasis-open.org/policies-guidelines/mailing-lists
Committee: https://www.oasis-open.org/committees/virtio/
Join OASIS: https://www.oasis-open.org/join/


  reply	other threads:[~2019-02-11  7:02 UTC|newest]

Thread overview: 6+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2019-01-31 13:16 [virtio-comment] VirtIO spec issue - Available Buffer Notification Suppression Savir, Gil
2019-02-11  6:58 ` Michael S. Tsirkin
2019-02-11  7:02   ` Michael S. Tsirkin [this message]
2019-02-21  8:57     ` Savir, Gil
2019-02-22  1:28       ` Michael S. Tsirkin
2019-02-26 20:30         ` Michael S. Tsirkin

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=20190211015836-mutt-send-email-mst@kernel.org \
    --to=mst@redhat.com \
    --cc=cunming.liang@intel.com \
    --cc=gil.savir@intel.com \
    --cc=liron.elmaleh@intel.com \
    --cc=virtio-comment@lists.oasis-open.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