[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PATCH v2 04/16] qemu-file: Account for rate_limit usage on qemu_ffl
From: |
Leonardo Brás |
Subject: |
Re: [PATCH v2 04/16] qemu-file: Account for rate_limit usage on qemu_fflush() |
Date: |
Wed, 24 May 2023 22:33:39 -0300 |
User-agent: |
Evolution 3.48.1 |
On Mon, 2023-05-15 at 21:56 +0200, Juan Quintela wrote:
> That is the moment we know we have transferred something.
>
> Signed-off-by: Juan Quintela <quintela@redhat.com>
> Reviewed-by: Cédric Le Goater <clg@kaod.org>
> ---
> migration/qemu-file.c | 7 +++----
> 1 file changed, 3 insertions(+), 4 deletions(-)
>
> diff --git a/migration/qemu-file.c b/migration/qemu-file.c
> index 4bc875b452..956bd2a580 100644
> --- a/migration/qemu-file.c
> +++ b/migration/qemu-file.c
> @@ -302,7 +302,9 @@ void qemu_fflush(QEMUFile *f)
> &local_error) < 0) {
> qemu_file_set_error_obj(f, -EIO, local_error);
> } else {
> - f->total_transferred += iov_size(f->iov, f->iovcnt);
> + uint64_t size = iov_size(f->iov, f->iovcnt);
> + qemu_file_acct_rate_limit(f, size);
> + f->total_transferred += size;
> }
>
> qemu_iovec_release_ram(f);
> @@ -519,7 +521,6 @@ void qemu_put_buffer_async(QEMUFile *f, const uint8_t
> *buf, size_t size,
> return;
> }
>
> - f->rate_limit_used += size;
> add_to_iovec(f, buf, size, may_free);
> }
>
> @@ -537,7 +538,6 @@ void qemu_put_buffer(QEMUFile *f, const uint8_t *buf,
> size_t size)
> l = size;
> }
> memcpy(f->buf + f->buf_index, buf, l);
> - f->rate_limit_used += l;
> add_buf_to_iovec(f, l);
> if (qemu_file_get_error(f)) {
> break;
> @@ -554,7 +554,6 @@ void qemu_put_byte(QEMUFile *f, int v)
> }
>
> f->buf[f->buf_index] = v;
> - f->rate_limit_used++;
> add_buf_to_iovec(f, 1);
> }
>
If we are counting transferred data at fflush, it makes sense to increase rate-
limit accounting at the same place. It may be less granular, but is more
efficient.
FWIW:
Reviewed-by: Leonardo Bras <leobras@redhat.com>
- Re: [PATCH v2 02/16] migration: Correct transferred bytes value, (continued)
[PATCH v2 03/16] migration: Move setup_time to mig_stats, Juan Quintela, 2023/05/15
Re: [PATCH v2 03/16] migration: Move setup_time to mig_stats, Leonardo Brás, 2023/05/24
[PATCH v2 04/16] qemu-file: Account for rate_limit usage on qemu_fflush(), Juan Quintela, 2023/05/15
- Re: [PATCH v2 04/16] qemu-file: Account for rate_limit usage on qemu_fflush(),
Leonardo Brás <=
[PATCH v2 06/16] migration: Move migration_total_bytes() to migration-stats.c, Juan Quintela, 2023/05/15
[PATCH v2 05/16] migration: Move rate_limit_max and rate_limit_used to migration_stats, Juan Quintela, 2023/05/15
[PATCH v2 07/16] migration: Add a trace for migration_transferred_bytes, Juan Quintela, 2023/05/15
[PATCH v2 08/16] migration: Use migration_transferred_bytes() to calculate rate_limit, Juan Quintela, 2023/05/15