Migration Pull request
Hi This is just fixes for migration. - Fix rdma (dave) - Remove unused variable (Zhijian) - Fix AVX512 and XBZRLE (Matheus) - Fix migration preempt (Peter) - Fix populate_vfio_info (Steve) - Fix multifd send trace (Wei) Please apply. Later, Juan. -----BEGIN PGP SIGNATURE----- iQIzBAABCAAdFiEEGJn/jt6/WMzuA0uC9IfvGFhy1yMFAmQTMa0ACgkQ9IfvGFhy 1yMKCBAAyHcE4TO3NrFpG87nGbLhr1zjXkLEKGuAA/E6NKKrf+OrSV2Wq0aBEO/B +yAAiXEPsjheh7gwS8FkgAgIj6PwRTtlKae/Tr0JtraukxYT4qzubkaw3X2VjEwf uJ8/I+BZOLBUxlZHYoyDP4CWX7elEMlzKdcShcpJCLTgLjxFXjQ9lZwQBgu51cF2 YitYRDMsVMr77y20eTqCUrLPcSgTM+8h3PtdyDRH2D+KF1IEkjGmSuF8lBc2WiN+ BiuW6RlaLjhQiBuWNbkrjdulArnim9qhIT5didJuE7p9L50WFSqZs3EV7a4fJjUl 1TWJ4k/fzcYf5GF1ypVBrZ1WWCsyJe/fd8ZddGyz9Xpu6Ml7BevVA+0oGeBDYaDB T7o2TrHzz2vYCl20jwPbUeafjN8MppBdtHaJ2pP0nA3cPZHPziU2BE9D2/AUxMib ICrNe+nVqXUKqx8qZrRPzIBsnoAgmhkNC/k8T7VEhfmm+s6C+xEE0eyhE299TYJn ETpQCqiDPCDlkC8iL3OAd8Nn8kucT7EL7qcV2PcpWxgKPc7mCCNIHdpfpM2aZduJ 0S/m19ICS8PSWSjFpSK2/vKLOyjA1PKA869iXFD+OOPb8jY5piTYOrj1gowkRjMx JOOVDX04lBxbgUVaZnC+iLuh/ZlMRFv2GFAHIk66XDsmUOzRddI= =Lwbm -----END PGP SIGNATURE----- Merge tag 'migration-20230316-pull-request' of https://gitlab.com/juan.quintela/qemu into staging Migration Pull request Hi This is just fixes for migration. - Fix rdma (dave) - Remove unused variable (Zhijian) - Fix AVX512 and XBZRLE (Matheus) - Fix migration preempt (Peter) - Fix populate_vfio_info (Steve) - Fix multifd send trace (Wei) Please apply. Later, Juan. # -----BEGIN PGP SIGNATURE----- # # iQIzBAABCAAdFiEEGJn/jt6/WMzuA0uC9IfvGFhy1yMFAmQTMa0ACgkQ9IfvGFhy # 1yMKCBAAyHcE4TO3NrFpG87nGbLhr1zjXkLEKGuAA/E6NKKrf+OrSV2Wq0aBEO/B # +yAAiXEPsjheh7gwS8FkgAgIj6PwRTtlKae/Tr0JtraukxYT4qzubkaw3X2VjEwf # uJ8/I+BZOLBUxlZHYoyDP4CWX7elEMlzKdcShcpJCLTgLjxFXjQ9lZwQBgu51cF2 # YitYRDMsVMr77y20eTqCUrLPcSgTM+8h3PtdyDRH2D+KF1IEkjGmSuF8lBc2WiN+ # BiuW6RlaLjhQiBuWNbkrjdulArnim9qhIT5didJuE7p9L50WFSqZs3EV7a4fJjUl # 1TWJ4k/fzcYf5GF1ypVBrZ1WWCsyJe/fd8ZddGyz9Xpu6Ml7BevVA+0oGeBDYaDB # T7o2TrHzz2vYCl20jwPbUeafjN8MppBdtHaJ2pP0nA3cPZHPziU2BE9D2/AUxMib # ICrNe+nVqXUKqx8qZrRPzIBsnoAgmhkNC/k8T7VEhfmm+s6C+xEE0eyhE299TYJn # ETpQCqiDPCDlkC8iL3OAd8Nn8kucT7EL7qcV2PcpWxgKPc7mCCNIHdpfpM2aZduJ # 0S/m19ICS8PSWSjFpSK2/vKLOyjA1PKA869iXFD+OOPb8jY5piTYOrj1gowkRjMx # JOOVDX04lBxbgUVaZnC+iLuh/ZlMRFv2GFAHIk66XDsmUOzRddI= # =Lwbm # -----END PGP SIGNATURE----- # gpg: Signature made Thu 16 Mar 2023 15:11:41 GMT # gpg: using RSA key 1899FF8EDEBF58CCEE034B82F487EF185872D723 # gpg: Good signature from "Juan Quintela <quintela@redhat.com>" [full] # gpg: aka "Juan Quintela <quintela@trasno.org>" [full] # Primary key fingerprint: 1899 FF8E DEBF 58CC EE03 4B82 F487 EF18 5872 D723 * tag 'migration-20230316-pull-request' of https://gitlab.com/juan.quintela/qemu: migration: fix populate_vfio_info migration/multifd: correct multifd_send_thread to trace the flags migration/rdma: Remove deprecated variable rdma_return_path migration/xbzrle: fix out-of-bounds write with axv512 migration/xbzrle: use ctz64 to avoid undefined result migration/rdma: Fix return-path case migration: Wait on preempt channel in preempt thread Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
commit
53b90ae9b5
@ -677,7 +677,7 @@ static void *multifd_send_thread(void *opaque)
|
|||||||
|
|
||||||
if (p->pending_job) {
|
if (p->pending_job) {
|
||||||
uint64_t packet_num = p->packet_num;
|
uint64_t packet_num = p->packet_num;
|
||||||
uint32_t flags = p->flags;
|
uint32_t flags;
|
||||||
p->normal_num = 0;
|
p->normal_num = 0;
|
||||||
|
|
||||||
if (use_zero_copy_send) {
|
if (use_zero_copy_send) {
|
||||||
@ -699,6 +699,7 @@ static void *multifd_send_thread(void *opaque)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
multifd_send_fill_packet(p);
|
multifd_send_fill_packet(p);
|
||||||
|
flags = p->flags;
|
||||||
p->flags = 0;
|
p->flags = 0;
|
||||||
p->num_packets++;
|
p->num_packets++;
|
||||||
p->total_normal_pages += p->normal_num;
|
p->total_normal_pages += p->normal_num;
|
||||||
|
@ -1197,11 +1197,6 @@ int postcopy_ram_incoming_setup(MigrationIncomingState *mis)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (migrate_postcopy_preempt()) {
|
if (migrate_postcopy_preempt()) {
|
||||||
/*
|
|
||||||
* The preempt channel is established in asynchronous way. Wait
|
|
||||||
* for its completion.
|
|
||||||
*/
|
|
||||||
qemu_sem_wait(&mis->postcopy_qemufile_dst_done);
|
|
||||||
/*
|
/*
|
||||||
* This thread needs to be created after the temp pages because
|
* This thread needs to be created after the temp pages because
|
||||||
* it'll fetch RAM_CHANNEL_POSTCOPY PostcopyTmpPage immediately.
|
* it'll fetch RAM_CHANNEL_POSTCOPY PostcopyTmpPage immediately.
|
||||||
@ -1668,6 +1663,12 @@ void *postcopy_preempt_thread(void *opaque)
|
|||||||
|
|
||||||
qemu_sem_post(&mis->thread_sync_sem);
|
qemu_sem_post(&mis->thread_sync_sem);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The preempt channel is established in asynchronous way. Wait
|
||||||
|
* for its completion.
|
||||||
|
*/
|
||||||
|
qemu_sem_wait(&mis->postcopy_qemufile_dst_done);
|
||||||
|
|
||||||
/* Sending RAM_SAVE_FLAG_EOS to terminate this thread */
|
/* Sending RAM_SAVE_FLAG_EOS to terminate this thread */
|
||||||
qemu_mutex_lock(&mis->postcopy_prio_thread_mutex);
|
qemu_mutex_lock(&mis->postcopy_prio_thread_mutex);
|
||||||
while (1) {
|
while (1) {
|
||||||
|
@ -3373,7 +3373,8 @@ static int qemu_rdma_accept(RDMAContext *rdma)
|
|||||||
* initialize the RDMAContext for return path for postcopy after first
|
* initialize the RDMAContext for return path for postcopy after first
|
||||||
* connection request reached.
|
* connection request reached.
|
||||||
*/
|
*/
|
||||||
if (migrate_postcopy() && !rdma->is_return_path) {
|
if ((migrate_postcopy() || migrate_use_return_path())
|
||||||
|
&& !rdma->is_return_path) {
|
||||||
rdma_return_path = qemu_rdma_data_init(rdma->host_port, NULL);
|
rdma_return_path = qemu_rdma_data_init(rdma->host_port, NULL);
|
||||||
if (rdma_return_path == NULL) {
|
if (rdma_return_path == NULL) {
|
||||||
rdma_ack_cm_event(cm_event);
|
rdma_ack_cm_event(cm_event);
|
||||||
@ -3455,7 +3456,8 @@ static int qemu_rdma_accept(RDMAContext *rdma)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Accept the second connection request for return path */
|
/* Accept the second connection request for return path */
|
||||||
if (migrate_postcopy() && !rdma->is_return_path) {
|
if ((migrate_postcopy() || migrate_use_return_path())
|
||||||
|
&& !rdma->is_return_path) {
|
||||||
qemu_set_fd_handler(rdma->channel->fd, rdma_accept_incoming_migration,
|
qemu_set_fd_handler(rdma->channel->fd, rdma_accept_incoming_migration,
|
||||||
NULL,
|
NULL,
|
||||||
(void *)(intptr_t)rdma->return_path);
|
(void *)(intptr_t)rdma->return_path);
|
||||||
@ -4109,7 +4111,7 @@ static void rdma_accept_incoming_migration(void *opaque)
|
|||||||
void rdma_start_incoming_migration(const char *host_port, Error **errp)
|
void rdma_start_incoming_migration(const char *host_port, Error **errp)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
RDMAContext *rdma, *rdma_return_path = NULL;
|
RDMAContext *rdma;
|
||||||
Error *local_err = NULL;
|
Error *local_err = NULL;
|
||||||
|
|
||||||
trace_rdma_start_incoming_migration();
|
trace_rdma_start_incoming_migration();
|
||||||
@ -4155,7 +4157,6 @@ err:
|
|||||||
g_free(rdma->host_port);
|
g_free(rdma->host_port);
|
||||||
}
|
}
|
||||||
g_free(rdma);
|
g_free(rdma);
|
||||||
g_free(rdma_return_path);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void rdma_start_outgoing_migration(void *opaque,
|
void rdma_start_outgoing_migration(void *opaque,
|
||||||
@ -4192,7 +4193,7 @@ void rdma_start_outgoing_migration(void *opaque,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* RDMA postcopy need a separate queue pair for return path */
|
/* RDMA postcopy need a separate queue pair for return path */
|
||||||
if (migrate_postcopy()) {
|
if (migrate_postcopy() || migrate_use_return_path()) {
|
||||||
rdma_return_path = qemu_rdma_data_init(host_port, errp);
|
rdma_return_path = qemu_rdma_data_init(host_port, errp);
|
||||||
|
|
||||||
if (rdma_return_path == NULL) {
|
if (rdma_return_path == NULL) {
|
||||||
|
@ -8,6 +8,7 @@
|
|||||||
#include "qemu/osdep.h"
|
#include "qemu/osdep.h"
|
||||||
#include "qapi/qapi-types-migration.h"
|
#include "qapi/qapi-types-migration.h"
|
||||||
#include "migration.h"
|
#include "migration.h"
|
||||||
|
#include CONFIG_DEVICES
|
||||||
|
|
||||||
#ifdef CONFIG_VFIO
|
#ifdef CONFIG_VFIO
|
||||||
#include "hw/vfio/vfio-common.h"
|
#include "hw/vfio/vfio-common.h"
|
||||||
@ -17,7 +18,6 @@ void populate_vfio_info(MigrationInfo *info)
|
|||||||
{
|
{
|
||||||
#ifdef CONFIG_VFIO
|
#ifdef CONFIG_VFIO
|
||||||
if (vfio_mig_active()) {
|
if (vfio_mig_active()) {
|
||||||
info->has_vfio = true;
|
|
||||||
info->vfio = g_malloc0(sizeof(*info->vfio));
|
info->vfio = g_malloc0(sizeof(*info->vfio));
|
||||||
info->vfio->transferred = vfio_mig_bytes_transferred();
|
info->vfio->transferred = vfio_mig_bytes_transferred();
|
||||||
}
|
}
|
||||||
|
@ -12,6 +12,7 @@
|
|||||||
*/
|
*/
|
||||||
#include "qemu/osdep.h"
|
#include "qemu/osdep.h"
|
||||||
#include "qemu/cutils.h"
|
#include "qemu/cutils.h"
|
||||||
|
#include "qemu/host-utils.h"
|
||||||
#include "xbzrle.h"
|
#include "xbzrle.h"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -196,10 +197,6 @@ int xbzrle_encode_buffer_avx512(uint8_t *old_buf, uint8_t *new_buf, int slen,
|
|||||||
__m512i r = _mm512_set1_epi32(0);
|
__m512i r = _mm512_set1_epi32(0);
|
||||||
|
|
||||||
while (count512s) {
|
while (count512s) {
|
||||||
if (d + 2 > dlen) {
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
int bytes_to_check = 64;
|
int bytes_to_check = 64;
|
||||||
uint64_t mask = 0xffffffffffffffff;
|
uint64_t mask = 0xffffffffffffffff;
|
||||||
if (count512s == 1) {
|
if (count512s == 1) {
|
||||||
@ -215,6 +212,9 @@ int xbzrle_encode_buffer_avx512(uint8_t *old_buf, uint8_t *new_buf, int slen,
|
|||||||
|
|
||||||
bool is_same = (comp & 0x1);
|
bool is_same = (comp & 0x1);
|
||||||
while (bytes_to_check) {
|
while (bytes_to_check) {
|
||||||
|
if (d + 2 > dlen) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
if (is_same) {
|
if (is_same) {
|
||||||
if (nzrun_len) {
|
if (nzrun_len) {
|
||||||
d += uleb128_encode_small(dst + d, nzrun_len);
|
d += uleb128_encode_small(dst + d, nzrun_len);
|
||||||
@ -233,7 +233,7 @@ int xbzrle_encode_buffer_avx512(uint8_t *old_buf, uint8_t *new_buf, int slen,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
never_same = false;
|
never_same = false;
|
||||||
num = __builtin_ctzll(~comp);
|
num = ctz64(~comp);
|
||||||
num = (num < bytes_to_check) ? num : bytes_to_check;
|
num = (num < bytes_to_check) ? num : bytes_to_check;
|
||||||
zrun_len += num;
|
zrun_len += num;
|
||||||
bytes_to_check -= num;
|
bytes_to_check -= num;
|
||||||
@ -262,7 +262,7 @@ int xbzrle_encode_buffer_avx512(uint8_t *old_buf, uint8_t *new_buf, int slen,
|
|||||||
nzrun_len += 64;
|
nzrun_len += 64;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
num = __builtin_ctzll(comp);
|
num = ctz64(comp);
|
||||||
num = (num < bytes_to_check) ? num : bytes_to_check;
|
num = (num < bytes_to_check) ? num : bytes_to_check;
|
||||||
nzrun_len += num;
|
nzrun_len += num;
|
||||||
bytes_to_check -= num;
|
bytes_to_check -= num;
|
||||||
|
Loading…
Reference in New Issue
Block a user