From: Jeff Cody <jcody@redhat.com>
To: Paolo Bonzini <pbonzini@redhat.com>
Cc: qemu-devel@nongnu.org, qemu-stable@nongnu.org,
qemu-block@nongnu.org, rjones@redhat.com
Subject: Re: [Qemu-devel] [PATCH 5/7] curl: convert CURLAIOCB to byte values
Date: Fri, 12 May 2017 17:38:33 -0400 [thread overview]
Message-ID: <20170512213833.GE19824@localhost.localdomain> (raw)
In-Reply-To: <20170510143205.32013-6-pbonzini@redhat.com>
On Wed, May 10, 2017 at 04:32:03PM +0200, Paolo Bonzini wrote:
> This is in preparation for the conversion from bdrv_aio_readv to
> bdrv_co_preadv, and it also requires changing some of the size_t values
> to uint64_t. This was broken before for disks > 2TB, but now it would
> break at 4GB.
>
> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
> ---
> block/curl.c | 44 ++++++++++++++++++++++----------------------
> 1 file changed, 22 insertions(+), 22 deletions(-)
>
> diff --git a/block/curl.c b/block/curl.c
> index 4b4d5a2389..3e288f2bc7 100644
> --- a/block/curl.c
> +++ b/block/curl.c
> @@ -96,8 +96,8 @@ typedef struct CURLAIOCB {
> BlockAIOCB common;
> QEMUIOVector *qiov;
>
> - int64_t sector_num;
> - int nb_sectors;
> + uint64_t offset;
> + uint64_t bytes;
>
> size_t start;
> size_t end;
> @@ -115,7 +115,7 @@ typedef struct CURLState
> CURL *curl;
> QLIST_HEAD(, CURLSocket) sockets;
> char *orig_buf;
> - size_t buf_start;
> + uint64_t buf_start;
> size_t buf_off;
> size_t buf_len;
> char range[128];
> @@ -126,7 +126,7 @@ typedef struct CURLState
> typedef struct BDRVCURLState {
> CURLM *multi;
> QEMUTimer timer;
> - size_t len;
> + uint64_t len;
> CURLState states[CURL_NUM_STATES];
> char *url;
> size_t readahead_size;
> @@ -257,7 +257,7 @@ static size_t curl_read_cb(void *ptr, size_t size, size_t nmemb, void *opaque)
> continue;
>
> if ((s->buf_off >= acb->end)) {
> - size_t request_length = acb->nb_sectors * BDRV_SECTOR_SIZE;
> + size_t request_length = acb->bytes;
>
> qemu_iovec_from_buf(acb->qiov, 0, s->orig_buf + acb->start,
> acb->end - acb->start);
> @@ -282,18 +282,18 @@ read_end:
> }
>
> /* Called with s->mutex held. */
> -static int curl_find_buf(BDRVCURLState *s, size_t start, size_t len,
> +static int curl_find_buf(BDRVCURLState *s, uint64_t start, uint64_t len,
> CURLAIOCB *acb)
> {
> int i;
> - size_t end = start + len;
> - size_t clamped_end = MIN(end, s->len);
> - size_t clamped_len = clamped_end - start;
> + uint64_t end = start + len;
> + uint64_t clamped_end = MIN(end, s->len);
> + uint64_t clamped_len = clamped_end - start;
>
> for (i=0; i<CURL_NUM_STATES; i++) {
> CURLState *state = &s->states[i];
> - size_t buf_end = (state->buf_start + state->buf_off);
> - size_t buf_fend = (state->buf_start + state->buf_len);
> + uint64_t buf_end = (state->buf_start + state->buf_off);
> + uint64_t buf_fend = (state->buf_start + state->buf_len);
>
> if (!state->orig_buf)
> continue;
> @@ -788,7 +788,7 @@ static int curl_open(BlockDriverState *bs, QDict *options, int flags,
> }
> #endif
>
> - s->len = (size_t)d;
> + s->len = d;
>
> if ((!strncasecmp(s->url, "http://", strlen("http://"))
> || !strncasecmp(s->url, "https://", strlen("https://")))
> @@ -797,7 +797,7 @@ static int curl_open(BlockDriverState *bs, QDict *options, int flags,
> "Server does not support 'range' (byte ranges).");
> goto out;
> }
> - DPRINTF("CURL: Size = %zd\n", s->len);
> + DPRINTF("CURL: Size = %" PRIu64 "\n", s->len);
>
> qemu_mutex_lock(&s->mutex);
> curl_clean_state(state);
> @@ -836,14 +836,14 @@ static void curl_readv_bh_cb(void *p)
> BlockDriverState *bs = acb->common.bs;
> BDRVCURLState *s = bs->opaque;
>
> - size_t start = acb->sector_num * BDRV_SECTOR_SIZE;
> - size_t end;
> + uint64_t start = acb->offset;
> + uint64_t end;
>
> qemu_mutex_lock(&s->mutex);
>
> // In case we have the requested data already (e.g. read-ahead),
> // we can just call the callback and be done.
> - switch (curl_find_buf(s, start, acb->nb_sectors * BDRV_SECTOR_SIZE, acb)) {
> + switch (curl_find_buf(s, start, acb->bytes, acb)) {
> case FIND_RET_OK:
> ret = 0;
> goto out;
> @@ -871,7 +871,7 @@ static void curl_readv_bh_cb(void *p)
> }
>
> acb->start = 0;
> - acb->end = MIN(acb->nb_sectors * BDRV_SECTOR_SIZE, s->len - start);
> + acb->end = MIN(acb->bytes, s->len - start);
>
> state->buf_off = 0;
> g_free(state->orig_buf);
> @@ -886,9 +886,9 @@ static void curl_readv_bh_cb(void *p)
> }
> state->acb[0] = acb;
>
> - snprintf(state->range, 127, "%zd-%zd", start, end);
> - DPRINTF("CURL (AIO): Reading %llu at %zd (%s)\n",
> - (acb->nb_sectors * BDRV_SECTOR_SIZE), start, state->range);
> + snprintf(state->range, 127, "%" PRIu64 "-%" PRIu64, start, end);
> + DPRINTF("CURL (AIO): Reading %" PRIu64 " at %" PRIu64 " (%s)\n",
> + acb->bytes, start, state->range);
> curl_easy_setopt(state->curl, CURLOPT_RANGE, state->range);
>
> curl_multi_add_handle(s->multi, state->curl);
> @@ -913,8 +913,8 @@ static BlockAIOCB *curl_aio_readv(BlockDriverState *bs,
> acb = qemu_aio_get(&curl_aiocb_info, bs, cb, opaque);
>
> acb->qiov = qiov;
> - acb->sector_num = sector_num;
> - acb->nb_sectors = nb_sectors;
> + acb->offset = sector_num * BDRV_SECTOR_SIZE;
> + acb->bytes = nb_sectors * BDRV_SECTOR_SIZE;
>
> aio_bh_schedule_oneshot(bdrv_get_aio_context(bs), curl_readv_bh_cb, acb);
> return &acb->common;
> --
> 2.12.2
>
>
Reviewed-by: Jeff Cody <jcody@redhat.com>
next prev parent reply other threads:[~2017-05-12 21:38 UTC|newest]
Thread overview: 28+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-05-10 14:31 [Qemu-devel] [PATCH v2 0/7] curl: locking cleanups/fixes, coroutine conversion, remove aio_poll Paolo Bonzini
2017-05-10 14:31 ` [Qemu-devel] [PATCH 1/7] curl: strengthen assertion in curl_clean_state Paolo Bonzini
2017-05-10 16:33 ` [Qemu-devel] [Qemu-block] " Max Reitz
2017-05-11 20:35 ` [Qemu-devel] " Jeff Cody
2017-05-10 14:32 ` [Qemu-devel] [PATCH 2/7] curl: never invoke callbacks with s->mutex held Paolo Bonzini
2017-05-10 16:33 ` [Qemu-devel] [Qemu-block] " Max Reitz
2017-05-11 20:40 ` [Qemu-devel] " Jeff Cody
2017-05-10 14:32 ` [Qemu-devel] [PATCH 3/7] curl: avoid recursive locking of BDRVCURLState mutex Paolo Bonzini
2017-05-10 16:38 ` [Qemu-devel] [Qemu-block] " Max Reitz
2017-05-11 20:56 ` [Qemu-devel] " Jeff Cody
2017-05-12 14:48 ` Paolo Bonzini
2017-05-10 14:32 ` [Qemu-devel] [PATCH 4/7] curl: split curl_find_state/curl_init_state Paolo Bonzini
2017-05-10 17:26 ` [Qemu-devel] [Qemu-block] " Max Reitz
2017-05-11 13:49 ` [Qemu-devel] " Paolo Bonzini
2017-05-12 21:38 ` Jeff Cody
2017-05-10 14:32 ` [Qemu-devel] [PATCH 5/7] curl: convert CURLAIOCB to byte values Paolo Bonzini
2017-05-10 17:36 ` [Qemu-devel] [Qemu-block] " Max Reitz
2017-05-10 18:37 ` Eric Blake
2017-05-12 21:38 ` Jeff Cody [this message]
2017-05-10 14:32 ` [Qemu-devel] [PATCH 6/7] curl: convert readv to coroutines Paolo Bonzini
2017-05-12 21:40 ` Jeff Cody
2017-05-10 14:32 ` [Qemu-devel] [PATCH 7/7] curl: do not do aio_poll when waiting for a free CURLState Paolo Bonzini
2017-05-10 17:54 ` [Qemu-devel] [Qemu-block] " Max Reitz
2017-05-12 21:41 ` [Qemu-devel] " Jeff Cody
2017-05-10 15:11 ` [Qemu-devel] [PATCH v2 0/7] curl: locking cleanups/fixes, coroutine conversion, remove aio_poll no-reply
2017-05-10 15:57 ` Richard W.M. Jones
2017-05-15 19:12 ` [Qemu-devel] [Qemu-block] " Max Reitz
2017-05-15 20:30 ` Richard W.M. Jones
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=20170512213833.GE19824@localhost.localdomain \
--to=jcody@redhat.com \
--cc=pbonzini@redhat.com \
--cc=qemu-block@nongnu.org \
--cc=qemu-devel@nongnu.org \
--cc=qemu-stable@nongnu.org \
--cc=rjones@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.