migration/multifd: put IOV initialization into compression method

Different compression methods may require different numbers of IOVs.
Based on streaming compression of zlib and zstd, all pages will be
compressed to a data block, so two IOVs are needed for packet header
and compressed data block.

Signed-off-by: Yuan Liu <yuan1.liu@intel.com>
Reviewed-by: Nanhai Zou <nanhai.zou@intel.com>
Reviewed-by: Fabiano Rosas <farosas@suse.de>
Reviewed-by: Peter Xu <peterx@redhat.com>
Signed-off-by: Fabiano Rosas <farosas@suse.de>
This commit is contained in:
Yuan Liu 2024-06-10 18:21:05 +08:00 committed by Fabiano Rosas
parent 0d40b3d76c
commit d9d3e4f243
3 changed files with 26 additions and 11 deletions

View File

@ -70,6 +70,10 @@ static int zlib_send_setup(MultiFDSendParams *p, Error **errp)
goto err_free_zbuff; goto err_free_zbuff;
} }
p->compress_data = z; p->compress_data = z;
/* Needs 2 IOVs, one for packet header and one for compressed data */
p->iov = g_new0(struct iovec, 2);
return 0; return 0;
err_free_zbuff: err_free_zbuff:
@ -101,6 +105,9 @@ static void zlib_send_cleanup(MultiFDSendParams *p, Error **errp)
z->buf = NULL; z->buf = NULL;
g_free(p->compress_data); g_free(p->compress_data);
p->compress_data = NULL; p->compress_data = NULL;
g_free(p->iov);
p->iov = NULL;
} }
/** /**

View File

@ -52,7 +52,6 @@ static int zstd_send_setup(MultiFDSendParams *p, Error **errp)
struct zstd_data *z = g_new0(struct zstd_data, 1); struct zstd_data *z = g_new0(struct zstd_data, 1);
int res; int res;
p->compress_data = z;
z->zcs = ZSTD_createCStream(); z->zcs = ZSTD_createCStream();
if (!z->zcs) { if (!z->zcs) {
g_free(z); g_free(z);
@ -77,6 +76,10 @@ static int zstd_send_setup(MultiFDSendParams *p, Error **errp)
error_setg(errp, "multifd %u: out of memory for zbuff", p->id); error_setg(errp, "multifd %u: out of memory for zbuff", p->id);
return -1; return -1;
} }
p->compress_data = z;
/* Needs 2 IOVs, one for packet header and one for compressed data */
p->iov = g_new0(struct iovec, 2);
return 0; return 0;
} }
@ -98,6 +101,9 @@ static void zstd_send_cleanup(MultiFDSendParams *p, Error **errp)
z->zbuff = NULL; z->zbuff = NULL;
g_free(p->compress_data); g_free(p->compress_data);
p->compress_data = NULL; p->compress_data = NULL;
g_free(p->iov);
p->iov = NULL;
} }
/** /**

View File

@ -137,6 +137,13 @@ static int nocomp_send_setup(MultiFDSendParams *p, Error **errp)
p->write_flags |= QIO_CHANNEL_WRITE_FLAG_ZERO_COPY; p->write_flags |= QIO_CHANNEL_WRITE_FLAG_ZERO_COPY;
} }
if (multifd_use_packets()) {
/* We need one extra place for the packet header */
p->iov = g_new0(struct iovec, p->page_count + 1);
} else {
p->iov = g_new0(struct iovec, p->page_count);
}
return 0; return 0;
} }
@ -150,6 +157,8 @@ static int nocomp_send_setup(MultiFDSendParams *p, Error **errp)
*/ */
static void nocomp_send_cleanup(MultiFDSendParams *p, Error **errp) static void nocomp_send_cleanup(MultiFDSendParams *p, Error **errp)
{ {
g_free(p->iov);
p->iov = NULL;
return; return;
} }
@ -228,6 +237,7 @@ static int nocomp_send_prepare(MultiFDSendParams *p, Error **errp)
*/ */
static int nocomp_recv_setup(MultiFDRecvParams *p, Error **errp) static int nocomp_recv_setup(MultiFDRecvParams *p, Error **errp)
{ {
p->iov = g_new0(struct iovec, p->page_count);
return 0; return 0;
} }
@ -240,6 +250,8 @@ static int nocomp_recv_setup(MultiFDRecvParams *p, Error **errp)
*/ */
static void nocomp_recv_cleanup(MultiFDRecvParams *p) static void nocomp_recv_cleanup(MultiFDRecvParams *p)
{ {
g_free(p->iov);
p->iov = NULL;
} }
/** /**
@ -783,8 +795,6 @@ static bool multifd_send_cleanup_channel(MultiFDSendParams *p, Error **errp)
p->packet_len = 0; p->packet_len = 0;
g_free(p->packet); g_free(p->packet);
p->packet = NULL; p->packet = NULL;
g_free(p->iov);
p->iov = NULL;
multifd_send_state->ops->send_cleanup(p, errp); multifd_send_state->ops->send_cleanup(p, errp);
return *errp == NULL; return *errp == NULL;
@ -1179,11 +1189,6 @@ bool multifd_send_setup(void)
p->packet = g_malloc0(p->packet_len); p->packet = g_malloc0(p->packet_len);
p->packet->magic = cpu_to_be32(MULTIFD_MAGIC); p->packet->magic = cpu_to_be32(MULTIFD_MAGIC);
p->packet->version = cpu_to_be32(MULTIFD_VERSION); p->packet->version = cpu_to_be32(MULTIFD_VERSION);
/* We need one extra place for the packet header */
p->iov = g_new0(struct iovec, page_count + 1);
} else {
p->iov = g_new0(struct iovec, page_count);
} }
p->name = g_strdup_printf("multifdsend_%d", i); p->name = g_strdup_printf("multifdsend_%d", i);
p->page_size = qemu_target_page_size(); p->page_size = qemu_target_page_size();
@ -1353,8 +1358,6 @@ static void multifd_recv_cleanup_channel(MultiFDRecvParams *p)
p->packet_len = 0; p->packet_len = 0;
g_free(p->packet); g_free(p->packet);
p->packet = NULL; p->packet = NULL;
g_free(p->iov);
p->iov = NULL;
g_free(p->normal); g_free(p->normal);
p->normal = NULL; p->normal = NULL;
g_free(p->zero); g_free(p->zero);
@ -1602,7 +1605,6 @@ int multifd_recv_setup(Error **errp)
p->packet = g_malloc0(p->packet_len); p->packet = g_malloc0(p->packet_len);
} }
p->name = g_strdup_printf("multifdrecv_%d", i); p->name = g_strdup_printf("multifdrecv_%d", i);
p->iov = g_new0(struct iovec, page_count);
p->normal = g_new0(ram_addr_t, page_count); p->normal = g_new0(ram_addr_t, page_count);
p->zero = g_new0(ram_addr_t, page_count); p->zero = g_new0(ram_addr_t, page_count);
p->page_count = page_count; p->page_count = page_count;