blob: 20e4c8e2dc84c90d48e01c8add803b71c5e1e941 [file] [log] [blame]
Juan Quinteladd4339c2017-04-17 17:07:04 +02001/*
2 * QEMU live migration channel operations
3 *
4 * Copyright Red Hat, Inc. 2016
5 *
6 * Authors:
7 * Daniel P. Berrange <berrange@redhat.com>
8 *
9 * Contributions after 2012-01-13 are licensed under the terms of the
10 * GNU GPL, version 2 or (at your option) any later version.
11 */
12
13#include "qemu/osdep.h"
14#include "channel.h"
Juan Quintela41d64222017-04-05 17:45:16 +020015#include "tls.h"
Juan Quintela6666c962017-04-24 20:07:27 +020016#include "migration.h"
Juan Quintela40014d82017-04-17 19:34:36 +020017#include "qemu-file-channel.h"
Juan Quinteladd4339c2017-04-17 17:07:04 +020018#include "trace.h"
19#include "qapi/error.h"
20#include "io/channel-tls.h"
21
Juan Quintela8e1a1932017-07-24 12:55:26 +020022/**
23 * @migration_channel_process_incoming - Create new incoming migration channel
24 *
25 * Notice that TLS is special. For it we listen in a listener socket,
26 * and then create a new client socket from the TLS library.
27 *
28 * @ioc: Channel to which we are connecting
29 */
Juan Quintela54314712017-04-17 17:15:02 +020030void migration_channel_process_incoming(QIOChannel *ioc)
Juan Quinteladd4339c2017-04-17 17:07:04 +020031{
Juan Quintela54314712017-04-17 17:15:02 +020032 MigrationState *s = migrate_get_current();
Fei Li49ed0d22019-01-13 22:08:46 +080033 Error *local_err = NULL;
Juan Quintela54314712017-04-17 17:15:02 +020034
Juan Quinteladd4339c2017-04-17 17:07:04 +020035 trace_migration_set_incoming_channel(
36 ioc, object_get_typename(OBJECT(ioc)));
37
38 if (s->parameters.tls_creds &&
39 *s->parameters.tls_creds &&
40 !object_dynamic_cast(OBJECT(ioc),
41 TYPE_QIO_CHANNEL_TLS)) {
Juan Quinteladd4339c2017-04-17 17:07:04 +020042 migration_tls_channel_process_incoming(s, ioc, &local_err);
Juan Quinteladd4339c2017-04-17 17:07:04 +020043 } else {
Fei Li49ed0d22019-01-13 22:08:46 +080044 migration_ioc_process_incoming(ioc, &local_err);
45 }
46
47 if (local_err) {
48 error_report_err(local_err);
Juan Quinteladd4339c2017-04-17 17:07:04 +020049 }
50}
51
52
Juan Quintela8e1a1932017-07-24 12:55:26 +020053/**
54 * @migration_channel_connect - Create new outgoing migration channel
55 *
56 * @s: Current migration state
57 * @ioc: Channel to which we are connecting
58 * @hostname: Where we want to connect
Dr. David Alan Gilbert688a3dc2017-12-15 17:16:55 +000059 * @error: Error indicating failure to connect, free'd here
Juan Quintela8e1a1932017-07-24 12:55:26 +020060 */
Juan Quinteladd4339c2017-04-17 17:07:04 +020061void migration_channel_connect(MigrationState *s,
62 QIOChannel *ioc,
Dr. David Alan Gilbert688a3dc2017-12-15 17:16:55 +000063 const char *hostname,
64 Error *error)
Juan Quinteladd4339c2017-04-17 17:07:04 +020065{
66 trace_migration_set_outgoing_channel(
Dr. David Alan Gilbert688a3dc2017-12-15 17:16:55 +000067 ioc, object_get_typename(OBJECT(ioc)), hostname, error);
Juan Quinteladd4339c2017-04-17 17:07:04 +020068
Dr. David Alan Gilbert688a3dc2017-12-15 17:16:55 +000069 if (!error) {
70 if (s->parameters.tls_creds &&
71 *s->parameters.tls_creds &&
72 !object_dynamic_cast(OBJECT(ioc),
73 TYPE_QIO_CHANNEL_TLS)) {
74 migration_tls_channel_connect(s, ioc, hostname, &error);
Dr. David Alan Gilbert8b7bf2b2018-04-30 19:59:43 +010075
76 if (!error) {
77 /* tls_channel_connect will call back to this
78 * function after the TLS handshake,
79 * so we mustn't call migrate_fd_connect until then
80 */
81
82 return;
83 }
Dr. David Alan Gilbert688a3dc2017-12-15 17:16:55 +000084 } else {
85 QEMUFile *f = qemu_fopen_channel_output(ioc);
86
Peter Xu62df0662018-05-02 18:47:38 +080087 qemu_mutex_lock(&s->qemu_file_lock);
Dr. David Alan Gilbert688a3dc2017-12-15 17:16:55 +000088 s->to_dst_file = f;
Peter Xu62df0662018-05-02 18:47:38 +080089 qemu_mutex_unlock(&s->qemu_file_lock);
Juan Quinteladd4339c2017-04-17 17:07:04 +020090 }
Juan Quinteladd4339c2017-04-17 17:07:04 +020091 }
Dr. David Alan Gilbert688a3dc2017-12-15 17:16:55 +000092 migrate_fd_connect(s, error);
93 error_free(error);
Juan Quinteladd4339c2017-04-17 17:07:04 +020094}