migration: Split migration/channel.c for channel operations
Create an include for its exported functions. Signed-off-by: Juan Quintela <quintela@redhat.com> Reviewed-by: Dr. David Alan Gilbert <dgilbert@redhat.com> --- Add proper header
This commit is contained in:
parent
709e3fe825
commit
dd4339c540
|
@ -157,17 +157,10 @@ void migration_fd_process_incoming(QEMUFile *f);
|
||||||
|
|
||||||
void qemu_start_incoming_migration(const char *uri, Error **errp);
|
void qemu_start_incoming_migration(const char *uri, Error **errp);
|
||||||
|
|
||||||
void migration_channel_process_incoming(MigrationState *s,
|
|
||||||
QIOChannel *ioc);
|
|
||||||
|
|
||||||
void migration_tls_channel_process_incoming(MigrationState *s,
|
void migration_tls_channel_process_incoming(MigrationState *s,
|
||||||
QIOChannel *ioc,
|
QIOChannel *ioc,
|
||||||
Error **errp);
|
Error **errp);
|
||||||
|
|
||||||
void migration_channel_connect(MigrationState *s,
|
|
||||||
QIOChannel *ioc,
|
|
||||||
const char *hostname);
|
|
||||||
|
|
||||||
void migration_tls_channel_connect(MigrationState *s,
|
void migration_tls_channel_connect(MigrationState *s,
|
||||||
QIOChannel *ioc,
|
QIOChannel *ioc,
|
||||||
const char *hostname,
|
const char *hostname,
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
common-obj-y += migration.o socket.o fd.o exec.o
|
common-obj-y += migration.o socket.o fd.o exec.o
|
||||||
common-obj-y += tls.o
|
common-obj-y += tls.o channel.o
|
||||||
common-obj-y += colo-comm.o colo.o colo-failover.o
|
common-obj-y += colo-comm.o colo.o colo-failover.o
|
||||||
common-obj-y += vmstate.o page_cache.o
|
common-obj-y += vmstate.o page_cache.o
|
||||||
common-obj-y += qemu-file.o
|
common-obj-y += qemu-file.o
|
||||||
|
|
|
@ -0,0 +1,66 @@
|
||||||
|
/*
|
||||||
|
* QEMU live migration channel operations
|
||||||
|
*
|
||||||
|
* Copyright Red Hat, Inc. 2016
|
||||||
|
*
|
||||||
|
* Authors:
|
||||||
|
* Daniel P. Berrange <berrange@redhat.com>
|
||||||
|
*
|
||||||
|
* Contributions after 2012-01-13 are licensed under the terms of the
|
||||||
|
* GNU GPL, version 2 or (at your option) any later version.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "qemu/osdep.h"
|
||||||
|
#include "channel.h"
|
||||||
|
#include "migration/migration.h"
|
||||||
|
#include "trace.h"
|
||||||
|
#include "qapi/error.h"
|
||||||
|
#include "io/channel-tls.h"
|
||||||
|
|
||||||
|
void migration_channel_process_incoming(MigrationState *s,
|
||||||
|
QIOChannel *ioc)
|
||||||
|
{
|
||||||
|
trace_migration_set_incoming_channel(
|
||||||
|
ioc, object_get_typename(OBJECT(ioc)));
|
||||||
|
|
||||||
|
if (s->parameters.tls_creds &&
|
||||||
|
*s->parameters.tls_creds &&
|
||||||
|
!object_dynamic_cast(OBJECT(ioc),
|
||||||
|
TYPE_QIO_CHANNEL_TLS)) {
|
||||||
|
Error *local_err = NULL;
|
||||||
|
migration_tls_channel_process_incoming(s, ioc, &local_err);
|
||||||
|
if (local_err) {
|
||||||
|
error_report_err(local_err);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
QEMUFile *f = qemu_fopen_channel_input(ioc);
|
||||||
|
migration_fd_process_incoming(f);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void migration_channel_connect(MigrationState *s,
|
||||||
|
QIOChannel *ioc,
|
||||||
|
const char *hostname)
|
||||||
|
{
|
||||||
|
trace_migration_set_outgoing_channel(
|
||||||
|
ioc, object_get_typename(OBJECT(ioc)), hostname);
|
||||||
|
|
||||||
|
if (s->parameters.tls_creds &&
|
||||||
|
*s->parameters.tls_creds &&
|
||||||
|
!object_dynamic_cast(OBJECT(ioc),
|
||||||
|
TYPE_QIO_CHANNEL_TLS)) {
|
||||||
|
Error *local_err = NULL;
|
||||||
|
migration_tls_channel_connect(s, ioc, hostname, &local_err);
|
||||||
|
if (local_err) {
|
||||||
|
migrate_fd_error(s, local_err);
|
||||||
|
error_free(local_err);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
QEMUFile *f = qemu_fopen_channel_output(ioc);
|
||||||
|
|
||||||
|
s->to_dst_file = f;
|
||||||
|
|
||||||
|
migrate_fd_connect(s);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,27 @@
|
||||||
|
/*
|
||||||
|
* QEMU live migration channel operations
|
||||||
|
*
|
||||||
|
* Copyright Red Hat, Inc. 2016
|
||||||
|
*
|
||||||
|
* Authors:
|
||||||
|
* Daniel P. Berrange <berrange@redhat.com>
|
||||||
|
*
|
||||||
|
* This work is licensed under the terms of the GNU GPL, version 2. See
|
||||||
|
* the COPYING file in the top-level directory.
|
||||||
|
*
|
||||||
|
* Contributions after 2012-01-13 are licensed under the terms of the
|
||||||
|
* GNU GPL, version 2 or (at your option) any later version.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef QEMU_MIGRATION_CHANNEL_H
|
||||||
|
#define QEMU_MIGRATION_CHANNEL_H
|
||||||
|
|
||||||
|
#include "io/channel.h"
|
||||||
|
|
||||||
|
void migration_channel_process_incoming(MigrationState *s,
|
||||||
|
QIOChannel *ioc);
|
||||||
|
|
||||||
|
void migration_channel_connect(MigrationState *s,
|
||||||
|
QIOChannel *ioc,
|
||||||
|
const char *hostname);
|
||||||
|
#endif
|
|
@ -20,6 +20,7 @@
|
||||||
#include "qemu/osdep.h"
|
#include "qemu/osdep.h"
|
||||||
#include "qapi/error.h"
|
#include "qapi/error.h"
|
||||||
#include "qemu-common.h"
|
#include "qemu-common.h"
|
||||||
|
#include "channel.h"
|
||||||
#include "migration/migration.h"
|
#include "migration/migration.h"
|
||||||
#include "io/channel-command.h"
|
#include "io/channel-command.h"
|
||||||
#include "trace.h"
|
#include "trace.h"
|
||||||
|
|
|
@ -17,6 +17,7 @@
|
||||||
#include "qemu/osdep.h"
|
#include "qemu/osdep.h"
|
||||||
#include "qapi/error.h"
|
#include "qapi/error.h"
|
||||||
#include "qemu-common.h"
|
#include "qemu-common.h"
|
||||||
|
#include "channel.h"
|
||||||
#include "migration/migration.h"
|
#include "migration/migration.h"
|
||||||
#include "monitor/monitor.h"
|
#include "monitor/monitor.h"
|
||||||
#include "io/channel-util.h"
|
#include "io/channel-util.h"
|
||||||
|
|
|
@ -444,56 +444,6 @@ void migration_fd_process_incoming(QEMUFile *f)
|
||||||
qemu_coroutine_enter(co);
|
qemu_coroutine_enter(co);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void migration_channel_process_incoming(MigrationState *s,
|
|
||||||
QIOChannel *ioc)
|
|
||||||
{
|
|
||||||
trace_migration_set_incoming_channel(
|
|
||||||
ioc, object_get_typename(OBJECT(ioc)));
|
|
||||||
|
|
||||||
if (s->parameters.tls_creds &&
|
|
||||||
*s->parameters.tls_creds &&
|
|
||||||
!object_dynamic_cast(OBJECT(ioc),
|
|
||||||
TYPE_QIO_CHANNEL_TLS)) {
|
|
||||||
Error *local_err = NULL;
|
|
||||||
migration_tls_channel_process_incoming(s, ioc, &local_err);
|
|
||||||
if (local_err) {
|
|
||||||
error_report_err(local_err);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
QEMUFile *f = qemu_fopen_channel_input(ioc);
|
|
||||||
migration_fd_process_incoming(f);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void migration_channel_connect(MigrationState *s,
|
|
||||||
QIOChannel *ioc,
|
|
||||||
const char *hostname)
|
|
||||||
{
|
|
||||||
trace_migration_set_outgoing_channel(
|
|
||||||
ioc, object_get_typename(OBJECT(ioc)), hostname);
|
|
||||||
|
|
||||||
if (s->parameters.tls_creds &&
|
|
||||||
*s->parameters.tls_creds &&
|
|
||||||
!object_dynamic_cast(OBJECT(ioc),
|
|
||||||
TYPE_QIO_CHANNEL_TLS)) {
|
|
||||||
Error *local_err = NULL;
|
|
||||||
migration_tls_channel_connect(s, ioc, hostname, &local_err);
|
|
||||||
if (local_err) {
|
|
||||||
migrate_fd_error(s, local_err);
|
|
||||||
error_free(local_err);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
QEMUFile *f = qemu_fopen_channel_output(ioc);
|
|
||||||
|
|
||||||
s->to_dst_file = f;
|
|
||||||
|
|
||||||
migrate_fd_connect(s);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Send a message on the return channel back to the source
|
* Send a message on the return channel back to the source
|
||||||
* of the migration.
|
* of the migration.
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
#include "qemu-common.h"
|
#include "qemu-common.h"
|
||||||
#include "qemu/error-report.h"
|
#include "qemu/error-report.h"
|
||||||
#include "qapi/error.h"
|
#include "qapi/error.h"
|
||||||
|
#include "channel.h"
|
||||||
#include "migration/migration.h"
|
#include "migration/migration.h"
|
||||||
#include "migration/qemu-file.h"
|
#include "migration/qemu-file.h"
|
||||||
#include "io/channel-socket.h"
|
#include "io/channel-socket.h"
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "qemu/osdep.h"
|
#include "qemu/osdep.h"
|
||||||
|
#include "channel.h"
|
||||||
#include "migration/migration.h"
|
#include "migration/migration.h"
|
||||||
#include "io/channel-tls.h"
|
#include "io/channel-tls.h"
|
||||||
#include "crypto/tlscreds.h"
|
#include "crypto/tlscreds.h"
|
||||||
|
|
Loading…
Reference in New Issue