From: Paolo Bonzini <pbonzini@redhat.com>
Cc: Kevin Wolf <kwolf@redhat.com>, qemu-devel@nongnu.org
Subject: Re: [Qemu-devel] [PATCH v3 03/15] add qemu_send_full and qemu_recv_full
Date: Fri, 14 Oct 2011 17:11:29 +0200 [thread overview]
Message-ID: <4E985121.7050707@redhat.com> (raw)
In-Reply-To: <4E980BF7.6020303@redhat.com>
On 10/14/2011 12:16 PM, Paolo Bonzini wrote:
> On 10/14/2011 11:52 AM, Kevin Wolf wrote:
>> Am 05.10.2011 09:17, schrieb Paolo Bonzini:
>>> Signed-off-by: Paolo Bonzini<pbonzini@redhat.com>
>>> ---
>>> osdep.c | 67 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++
>>> qemu-common.h | 4 +++
>>> 2 files changed, 71 insertions(+), 0 deletions(-)
>>>
>>> diff --git a/osdep.c b/osdep.c
>>> index 56e6963..718a25d 100644
>>> --- a/osdep.c
>>> +++ b/osdep.c
>>> @@ -166,3 +166,70 @@ int qemu_accept(int s, struct sockaddr *addr,
>>> socklen_t *addrlen)
>>>
>>> return ret;
>>> }
>>> +
>>> +/*
>>> + * A variant of send(2) which handles partial write.
>>> + *
>>> + * Return the number of bytes transferred, which is only
>>> + * smaller than `count' if there is an error.
>>> + *
>>> + * This function won't work with non-blocking fd's.
>>> + * Any of the possibilities with non-bloking fd's is bad:
>>> + * - return a short write (then name is wrong)
>>> + * - busy wait adding (errno == EAGAIN) to the loop
>>> + */
>>> +ssize_t qemu_send_full(int fd, const void *buf, size_t count, int
>>> flags)
>>> +{
>>> + ssize_t ret = 0;
>>> + ssize_t total = 0;
>>> +
>>> + while (count) {
>>> + ret = send(fd, buf, count, flags);
>>> + if (ret< 0) {
>>> + if (errno == EINTR) {
>>> + continue;
>>> + }
>>> + break;
>>> + }
>>> +
>>> + count -= ret;
>>> + buf += ret;
>>> + total += ret;
>>> + }
>>> +
>>> + return total;
>>> +}
>>> +
>>> +/*
>>> + * A variant of recv(2) which handles partial write.
>>> + *
>>> + * Return the number of bytes transferred, which is only
>>> + * smaller than `count' if there is an error.
>>> + *
>>> + * This function won't work with non-blocking fd's.
>>> + * Any of the possibilities with non-bloking fd's is bad:
>>> + * - return a short write (then name is wrong)
>>> + * - busy wait adding (errno == EAGAIN) to the loop
>>> + */
>>> +ssize_t qemu_recv_full(int fd, const void *buf, size_t count, int
>>> flags)
>>> +{
>>> + ssize_t ret = 0;
>>> + ssize_t total = 0;
>>> +
>>> + while (count) {
>>> + ret = recv(fd, buf, count, flags);
>>
>> osdep.c: In function 'qemu_recv_full':
>> osdep.c:220: error: passing argument 2 of 'recv' discards qualifiers
>> from pointer target type
>> /usr/include/bits/socket2.h:35: note: expected 'void *' but argument is
>> of type 'const void *'
>
> It's fixed in 4/15's osdep.c. I attach the diff, and pushed the fixed
> version to github nbd-trim.
>
> Also, all branches there are now rebased on top of block branch.
Let's keep this out of 1.0 (having to choose I very much choose scsi
over nbd! :)). I'll try to get all the prerequisites in though, so that
they will get thorough testing and the nbd parts will be easier to
manage afterwards.
Paolo
next prev parent reply other threads:[~2011-10-14 15:11 UTC|newest]
Thread overview: 20+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-10-05 7:17 [Qemu-devel] [PATCH v3 00/15] NBD improvements Paolo Bonzini
2011-10-05 7:17 ` [Qemu-devel] [PATCH v3 01/15] sheepdog: add coroutine_fn markers Paolo Bonzini
2011-10-05 7:17 ` [Qemu-devel] [PATCH v3 02/15] add socket_set_block Paolo Bonzini
2011-10-05 7:17 ` [Qemu-devel] [PATCH v3 03/15] add qemu_send_full and qemu_recv_full Paolo Bonzini
2011-10-14 9:52 ` Kevin Wolf
2011-10-14 10:16 ` Paolo Bonzini
2011-10-14 15:11 ` Paolo Bonzini [this message]
2011-10-05 7:17 ` [Qemu-devel] [PATCH v3 04/15] sheepdog: move coroutine send/recv function to generic code Paolo Bonzini
2011-10-05 7:17 ` [Qemu-devel] [PATCH v3 05/15] block: emulate .bdrv_flush() using .bdrv_aio_flush() Paolo Bonzini
2011-10-05 7:17 ` [Qemu-devel] [PATCH v3 06/15] block: group together the plugging of synchronous IO emulation Paolo Bonzini
2011-10-05 7:17 ` [Qemu-devel] [PATCH v3 07/15] block: add bdrv_co_flush support Paolo Bonzini
2011-10-05 7:17 ` [Qemu-devel] [PATCH v3 08/15] block: add bdrv_co_discard and bdrv_aio_discard support Paolo Bonzini
2011-10-05 7:17 ` [Qemu-devel] [PATCH v3 09/15] nbd: fix error handling in the server Paolo Bonzini
2011-10-05 7:17 ` [Qemu-devel] [PATCH v3 10/15] nbd: add support for NBD_CMD_FLUSH Paolo Bonzini
2011-10-05 7:17 ` [Qemu-devel] [PATCH v3 11/15] nbd: add support for NBD_CMD_FLAG_FUA Paolo Bonzini
2011-10-05 7:17 ` [Qemu-devel] [PATCH v3 12/15] nbd: add support for NBD_CMD_TRIM Paolo Bonzini
2011-10-05 7:17 ` [Qemu-devel] [PATCH v3 13/15] nbd: switch to asynchronous operation Paolo Bonzini
2011-10-05 7:17 ` [Qemu-devel] [PATCH v3 14/15] nbd: split requests Paolo Bonzini
2011-10-05 7:17 ` [Qemu-devel] [PATCH v3 15/15] nbd: allow multiple in-flight requests Paolo Bonzini
2011-10-13 15:04 ` [Qemu-devel] [PATCH v3 00/15] NBD improvements Paolo Bonzini
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=4E985121.7050707@redhat.com \
--to=pbonzini@redhat.com \
--cc=kwolf@redhat.com \
--cc=qemu-devel@nongnu.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).