All of lore.kernel.org
 help / color / mirror / Atom feed
From: Paolo Bonzini <pbonzini@redhat.com>
To: Stefan Hajnoczi <stefanha@redhat.com>
Cc: Kevin Wolf <kwolf@redhat.com>,
	Stefan Hajnoczi <stefanha@gmail.com>, Fam Zheng <famz@redhat.com>,
	qemu-devel@nongnu.org, Max Reitz <mreitz@redhat.com>
Subject: Re: [Qemu-devel] [RFC 3/5] nbd: Use aio_set_fd_handler2()
Date: Thu, 05 Jun 2014 11:27:49 +0200	[thread overview]
Message-ID: <53903815.3030809@redhat.com> (raw)
In-Reply-To: <20140605081223.GB27366@stefanha-thinkpad.redhat.com>

Il 05/06/2014 10:12, Stefan Hajnoczi ha scritto:
> On Wed, Jun 04, 2014 at 08:02:06PM +0200, Paolo Bonzini wrote:
>> Il 04/06/2014 14:37, Stefan Hajnoczi ha scritto:
>>> Why is this design cleaner?  Because NBD code doesn't have to worry
>>> about fd handlers.  It uses straightforward coroutine send/recv for
>>> socket I/O inside nbd_read_req() and nbd_write_resp().  It's easy to see
>>> that only one coroutine receives from the socket and that only one
>>> coroutine writes to the socket.
>>
>> I don't understand how this would work without managing fd handlers.
>
> fd handlers still need to be managed, but not by NBD code.  They must be
> managed by coroutine recv/send utility functions.  In other words, fd
> handlers are used locally, not globally.
>
> def co_recv(fd, buf):
>     while True:
>         nbytes = recv(fd, buf, len(buf))
>         if nbytes == -1:
>             if errno == EINTR:
>                 continue
>             if errno == EAGAIN or errno == EWOULDBLOCK:
>                 aio_set_fd_read_handler(fd, co_recv_cb)
>                 qemu_coroutine_yield()
>                 aio_set_fd_read_handler(fd, NULL)
>                 continue
>         return nbytes
>
> The send function is similar.

I see what you mean now---this however is not how qemu_co_recv and 
qemu_co_send work.  NBD uses them, but they require the caller to set up 
the handlers manually.

Paolo

  reply	other threads:[~2014-06-05  9:28 UTC|newest]

Thread overview: 20+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <1401561792-13410-1-git-send-email-mreitz@redhat.com>
2014-06-03 14:38 ` [Qemu-devel] [RFC 0/5] nbd: Adapt for dataplane Stefan Hajnoczi
2014-06-05 17:41   ` Max Reitz
     [not found] ` <1401561792-13410-3-git-send-email-mreitz@redhat.com>
2014-06-03 17:55   ` [Qemu-devel] [RFC 2/5] aio: Add io_read_poll() callback Paolo Bonzini
2014-06-05 17:29     ` Max Reitz
2014-06-04 11:59   ` Stefan Hajnoczi
     [not found] ` <1401561792-13410-2-git-send-email-mreitz@redhat.com>
2014-06-04 11:52   ` [Qemu-devel] [RFC 1/5] nbd: Correct name comparison for export_set_name() Stefan Hajnoczi
2014-06-05 17:28     ` Max Reitz
     [not found] ` <1401561792-13410-4-git-send-email-mreitz@redhat.com>
2014-06-04 12:37   ` [Qemu-devel] [RFC 3/5] nbd: Use aio_set_fd_handler2() Stefan Hajnoczi
2014-06-04 18:02     ` Paolo Bonzini
2014-06-05  8:12       ` Stefan Hajnoczi
2014-06-05  9:27         ` Paolo Bonzini [this message]
2014-06-05 13:32           ` Stefan Hajnoczi
2014-06-05 18:18     ` Max Reitz
2014-06-06  7:44       ` Paolo Bonzini
2014-06-07 19:27         ` Max Reitz
2014-06-09 13:35           ` Stefan Hajnoczi
     [not found] ` <1401561792-13410-5-git-send-email-mreitz@redhat.com>
2014-06-04 12:41   ` [Qemu-devel] [RFC 4/5] block: Add AIO followers Stefan Hajnoczi
2014-06-05 17:31     ` Max Reitz
     [not found] ` <538A3A8F.3060508@redhat.com>
2014-06-04 12:47   ` [Qemu-devel] [RFC 0/5] nbd: Adapt for dataplane Stefan Hajnoczi
2014-06-04 12:50 ` Stefan Hajnoczi

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=53903815.3030809@redhat.com \
    --to=pbonzini@redhat.com \
    --cc=famz@redhat.com \
    --cc=kwolf@redhat.com \
    --cc=mreitz@redhat.com \
    --cc=qemu-devel@nongnu.org \
    --cc=stefanha@gmail.com \
    --cc=stefanha@redhat.com \
    /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.