migration/multifd: Join the TLS thread
We're currently leaking the resources of the TLS thread by not joining
it and also overwriting the p->thread pointer altogether.
Fixes: a1af605bd5
("migration/multifd: fix hangup with TLS-Multifd due to blocking handshake")
Cc: qemu-stable <qemu-stable@nongnu.org>
Reviewed-by: Peter Xu <peterx@redhat.com>
Signed-off-by: Fabiano Rosas <farosas@suse.de>
Link: https://lore.kernel.org/r/20240206215118.6171-2-farosas@suse.de
Signed-off-by: Peter Xu <peterx@redhat.com>
This commit is contained in:
parent
3205bebd4f
commit
e1921f10d9
@ -630,6 +630,10 @@ static void multifd_send_terminate_threads(void)
|
|||||||
for (i = 0; i < migrate_multifd_channels(); i++) {
|
for (i = 0; i < migrate_multifd_channels(); i++) {
|
||||||
MultiFDSendParams *p = &multifd_send_state->params[i];
|
MultiFDSendParams *p = &multifd_send_state->params[i];
|
||||||
|
|
||||||
|
if (p->tls_thread_created) {
|
||||||
|
qemu_thread_join(&p->tls_thread);
|
||||||
|
}
|
||||||
|
|
||||||
if (p->running) {
|
if (p->running) {
|
||||||
qemu_thread_join(&p->thread);
|
qemu_thread_join(&p->thread);
|
||||||
}
|
}
|
||||||
@ -921,7 +925,9 @@ static bool multifd_tls_channel_connect(MultiFDSendParams *p,
|
|||||||
trace_multifd_tls_outgoing_handshake_start(ioc, tioc, hostname);
|
trace_multifd_tls_outgoing_handshake_start(ioc, tioc, hostname);
|
||||||
qio_channel_set_name(QIO_CHANNEL(tioc), "multifd-tls-outgoing");
|
qio_channel_set_name(QIO_CHANNEL(tioc), "multifd-tls-outgoing");
|
||||||
p->c = QIO_CHANNEL(tioc);
|
p->c = QIO_CHANNEL(tioc);
|
||||||
qemu_thread_create(&p->thread, "multifd-tls-handshake-worker",
|
|
||||||
|
p->tls_thread_created = true;
|
||||||
|
qemu_thread_create(&p->tls_thread, "multifd-tls-handshake-worker",
|
||||||
multifd_tls_handshake_thread, p,
|
multifd_tls_handshake_thread, p,
|
||||||
QEMU_THREAD_JOINABLE);
|
QEMU_THREAD_JOINABLE);
|
||||||
return true;
|
return true;
|
||||||
|
@ -73,6 +73,8 @@ typedef struct {
|
|||||||
char *name;
|
char *name;
|
||||||
/* channel thread id */
|
/* channel thread id */
|
||||||
QemuThread thread;
|
QemuThread thread;
|
||||||
|
QemuThread tls_thread;
|
||||||
|
bool tls_thread_created;
|
||||||
/* communication channel */
|
/* communication channel */
|
||||||
QIOChannel *c;
|
QIOChannel *c;
|
||||||
/* is the yank function registered */
|
/* is the yank function registered */
|
||||||
|
Loading…
Reference in New Issue
Block a user