1be5c7
From 8cdedf86dc193673ea24516e7b44f8b4da5dd713 Mon Sep 17 00:00:00 2001
1be5c7
From: Juan Quintela <quintela@redhat.com>
1be5c7
Date: Wed, 18 May 2022 02:52:23 -0300
1be5c7
Subject: [PATCH 06/37] multifd: remove used parameter from send_recv_pages()
1be5c7
 method
1be5c7
MIME-Version: 1.0
1be5c7
Content-Type: text/plain; charset=UTF-8
1be5c7
Content-Transfer-Encoding: 8bit
1be5c7
1be5c7
RH-Author: Leonardo Brás <leobras@redhat.com>
1be5c7
RH-MergeRequest: 191: MSG_ZEROCOPY + Multifd @ rhel8.7
1be5c7
RH-Commit: [6/26] 5c1a506e4178501a0894ea4e7ac919e1d4d4cc32
1be5c7
RH-Bugzilla: 2072049
1be5c7
RH-Acked-by: Peter Xu <peterx@redhat.com>
1be5c7
RH-Acked-by: Daniel P. Berrangé <berrange@redhat.com>
1be5c7
RH-Acked-by: Dr. David Alan Gilbert <dgilbert@redhat.com>
1be5c7
1be5c7
It is already there as p->pages->num.
1be5c7
1be5c7
Signed-off-by: Juan Quintela <quintela@redhat.com>
1be5c7
Reviewed-by: Dr. David Alan Gilbert <dgilbert@redhat.com>
1be5c7
(cherry picked from commit 40a4bfe9d3f8ad35a9c3ffb4cbf7367e2777054b)
1be5c7
Signed-off-by: Leonardo Bras <leobras@redhat.com>
1be5c7
---
1be5c7
 migration/multifd-zlib.c | 9 ++++-----
1be5c7
 migration/multifd-zstd.c | 7 +++----
1be5c7
 migration/multifd.c      | 7 +++----
1be5c7
 migration/multifd.h      | 2 +-
1be5c7
 4 files changed, 11 insertions(+), 14 deletions(-)
1be5c7
1be5c7
diff --git a/migration/multifd-zlib.c b/migration/multifd-zlib.c
1be5c7
index 0c70a2dc78..330fc021c5 100644
1be5c7
--- a/migration/multifd-zlib.c
1be5c7
+++ b/migration/multifd-zlib.c
1be5c7
@@ -235,17 +235,16 @@ static void zlib_recv_cleanup(MultiFDRecvParams *p)
1be5c7
  * Returns 0 for success or -1 for error
1be5c7
  *
1be5c7
  * @p: Params for the channel that we are using
1be5c7
- * @used: number of pages used
1be5c7
  * @errp: pointer to an error
1be5c7
  */
1be5c7
-static int zlib_recv_pages(MultiFDRecvParams *p, uint32_t used, Error **errp)
1be5c7
+static int zlib_recv_pages(MultiFDRecvParams *p, Error **errp)
1be5c7
 {
1be5c7
     struct zlib_data *z = p->data;
1be5c7
     z_stream *zs = &z->zs;
1be5c7
     uint32_t in_size = p->next_packet_size;
1be5c7
     /* we measure the change of total_out */
1be5c7
     uint32_t out_size = zs->total_out;
1be5c7
-    uint32_t expected_size = used * qemu_target_page_size();
1be5c7
+    uint32_t expected_size = p->pages->num * qemu_target_page_size();
1be5c7
     uint32_t flags = p->flags & MULTIFD_FLAG_COMPRESSION_MASK;
1be5c7
     int ret;
1be5c7
     int i;
1be5c7
@@ -264,12 +263,12 @@ static int zlib_recv_pages(MultiFDRecvParams *p, uint32_t used, Error **errp)
1be5c7
     zs->avail_in = in_size;
1be5c7
     zs->next_in = z->zbuff;
1be5c7
 
1be5c7
-    for (i = 0; i < used; i++) {
1be5c7
+    for (i = 0; i < p->pages->num; i++) {
1be5c7
         struct iovec *iov = &p->pages->iov[i];
1be5c7
         int flush = Z_NO_FLUSH;
1be5c7
         unsigned long start = zs->total_out;
1be5c7
 
1be5c7
-        if (i == used - 1) {
1be5c7
+        if (i == p->pages->num - 1) {
1be5c7
             flush = Z_SYNC_FLUSH;
1be5c7
         }
1be5c7
 
1be5c7
diff --git a/migration/multifd-zstd.c b/migration/multifd-zstd.c
1be5c7
index 466b370cad..f0d1105792 100644
1be5c7
--- a/migration/multifd-zstd.c
1be5c7
+++ b/migration/multifd-zstd.c
1be5c7
@@ -255,14 +255,13 @@ static void zstd_recv_cleanup(MultiFDRecvParams *p)
1be5c7
  * Returns 0 for success or -1 for error
1be5c7
  *
1be5c7
  * @p: Params for the channel that we are using
1be5c7
- * @used: number of pages used
1be5c7
  * @errp: pointer to an error
1be5c7
  */
1be5c7
-static int zstd_recv_pages(MultiFDRecvParams *p, uint32_t used, Error **errp)
1be5c7
+static int zstd_recv_pages(MultiFDRecvParams *p, Error **errp)
1be5c7
 {
1be5c7
     uint32_t in_size = p->next_packet_size;
1be5c7
     uint32_t out_size = 0;
1be5c7
-    uint32_t expected_size = used * qemu_target_page_size();
1be5c7
+    uint32_t expected_size = p->pages->num * qemu_target_page_size();
1be5c7
     uint32_t flags = p->flags & MULTIFD_FLAG_COMPRESSION_MASK;
1be5c7
     struct zstd_data *z = p->data;
1be5c7
     int ret;
1be5c7
@@ -283,7 +282,7 @@ static int zstd_recv_pages(MultiFDRecvParams *p, uint32_t used, Error **errp)
1be5c7
     z->in.size = in_size;
1be5c7
     z->in.pos = 0;
1be5c7
 
1be5c7
-    for (i = 0; i < used; i++) {
1be5c7
+    for (i = 0; i < p->pages->num; i++) {
1be5c7
         struct iovec *iov = &p->pages->iov[i];
1be5c7
 
1be5c7
         z->out.dst = iov->iov_base;
1be5c7
diff --git a/migration/multifd.c b/migration/multifd.c
1be5c7
index 098ef8842c..55d99a8232 100644
1be5c7
--- a/migration/multifd.c
1be5c7
+++ b/migration/multifd.c
1be5c7
@@ -141,10 +141,9 @@ static void nocomp_recv_cleanup(MultiFDRecvParams *p)
1be5c7
  * Returns 0 for success or -1 for error
1be5c7
  *
1be5c7
  * @p: Params for the channel that we are using
1be5c7
- * @used: number of pages used
1be5c7
  * @errp: pointer to an error
1be5c7
  */
1be5c7
-static int nocomp_recv_pages(MultiFDRecvParams *p, uint32_t used, Error **errp)
1be5c7
+static int nocomp_recv_pages(MultiFDRecvParams *p, Error **errp)
1be5c7
 {
1be5c7
     uint32_t flags = p->flags & MULTIFD_FLAG_COMPRESSION_MASK;
1be5c7
 
1be5c7
@@ -153,7 +152,7 @@ static int nocomp_recv_pages(MultiFDRecvParams *p, uint32_t used, Error **errp)
1be5c7
                    p->id, flags, MULTIFD_FLAG_NOCOMP);
1be5c7
         return -1;
1be5c7
     }
1be5c7
-    return qio_channel_readv_all(p->c, p->pages->iov, used, errp);
1be5c7
+    return qio_channel_readv_all(p->c, p->pages->iov, p->pages->num, errp);
1be5c7
 }
1be5c7
 
1be5c7
 static MultiFDMethods multifd_nocomp_ops = {
1be5c7
@@ -1099,7 +1098,7 @@ static void *multifd_recv_thread(void *opaque)
1be5c7
         qemu_mutex_unlock(&p->mutex);
1be5c7
 
1be5c7
         if (used) {
1be5c7
-            ret = multifd_recv_state->ops->recv_pages(p, used, &local_err);
1be5c7
+            ret = multifd_recv_state->ops->recv_pages(p, &local_err);
1be5c7
             if (ret != 0) {
1be5c7
                 break;
1be5c7
             }
1be5c7
diff --git a/migration/multifd.h b/migration/multifd.h
1be5c7
index 7968cc5c20..e57adc783b 100644
1be5c7
--- a/migration/multifd.h
1be5c7
+++ b/migration/multifd.h
1be5c7
@@ -167,7 +167,7 @@ typedef struct {
1be5c7
     /* Cleanup for receiving side */
1be5c7
     void (*recv_cleanup)(MultiFDRecvParams *p);
1be5c7
     /* Read all pages */
1be5c7
-    int (*recv_pages)(MultiFDRecvParams *p, uint32_t used, Error **errp);
1be5c7
+    int (*recv_pages)(MultiFDRecvParams *p, Error **errp);
1be5c7
 } MultiFDMethods;
1be5c7
 
1be5c7
 void multifd_register_ops(int method, MultiFDMethods *ops);
1be5c7
-- 
1be5c7
2.35.3
1be5c7