mirror of
https://github.com/Motorhead1991/qemu.git
synced 2026-01-05 14:07:41 -07:00
Merge remote branch 'spice/spice.v29.pull' into staging
Conflicts: trace-events
This commit is contained in:
commit
9363ee31ab
17 changed files with 391 additions and 80 deletions
|
|
@ -24,6 +24,7 @@
|
|||
|
||||
#include "qemu-option.h"
|
||||
#include "qemu-config.h"
|
||||
#include "qemu-char.h"
|
||||
|
||||
extern int using_spice;
|
||||
|
||||
|
|
@ -35,15 +36,21 @@ int qemu_spice_add_interface(SpiceBaseInstance *sin);
|
|||
int qemu_spice_set_passwd(const char *passwd,
|
||||
bool fail_if_connected, bool disconnect_if_connected);
|
||||
int qemu_spice_set_pw_expire(time_t expires);
|
||||
int qemu_spice_migrate_info(const char *hostname, int port, int tls_port,
|
||||
const char *subject);
|
||||
|
||||
void do_info_spice_print(Monitor *mon, const QObject *data);
|
||||
void do_info_spice(Monitor *mon, QObject **ret_data);
|
||||
|
||||
CharDriverState *qemu_chr_open_spice(QemuOpts *opts);
|
||||
|
||||
#else /* CONFIG_SPICE */
|
||||
|
||||
#define using_spice 0
|
||||
#define qemu_spice_set_passwd(_p, _f1, _f2) (-1)
|
||||
#define qemu_spice_set_pw_expire(_e) (-1)
|
||||
static inline int qemu_spice_migrate_info(const char *h, int p, int t, const char *s)
|
||||
{ return -1; }
|
||||
|
||||
#endif /* CONFIG_SPICE */
|
||||
|
||||
|
|
|
|||
|
|
@ -30,11 +30,15 @@
|
|||
#include "qbool.h"
|
||||
#include "qstring.h"
|
||||
#include "qjson.h"
|
||||
#include "notify.h"
|
||||
#include "migration.h"
|
||||
#include "monitor.h"
|
||||
#include "hw/hw.h"
|
||||
|
||||
/* core bits */
|
||||
|
||||
static SpiceServer *spice_server;
|
||||
static Notifier migration_state;
|
||||
static const char *auth = "spice";
|
||||
static char *auth_passwd;
|
||||
static time_t auth_expires = TIME_MAX;
|
||||
|
|
@ -416,6 +420,24 @@ void do_info_spice(Monitor *mon, QObject **ret_data)
|
|||
*ret_data = QOBJECT(server);
|
||||
}
|
||||
|
||||
static void migration_state_notifier(Notifier *notifier)
|
||||
{
|
||||
int state = get_migration_state();
|
||||
|
||||
if (state == MIG_STATE_COMPLETED) {
|
||||
#if SPICE_SERVER_VERSION >= 0x000701 /* 0.7.1 */
|
||||
spice_server_migrate_switch(spice_server);
|
||||
#endif
|
||||
}
|
||||
}
|
||||
|
||||
int qemu_spice_migrate_info(const char *hostname, int port, int tls_port,
|
||||
const char *subject)
|
||||
{
|
||||
return spice_server_migrate_info(spice_server, hostname,
|
||||
port, tls_port, subject);
|
||||
}
|
||||
|
||||
static int add_channel(const char *name, const char *value, void *opaque)
|
||||
{
|
||||
int security = 0;
|
||||
|
|
@ -573,6 +595,9 @@ void qemu_spice_init(void)
|
|||
spice_server_init(spice_server, &core_interface);
|
||||
using_spice = 1;
|
||||
|
||||
migration_state.notify = migration_state_notifier;
|
||||
add_migration_state_change_notifier(&migration_state);
|
||||
|
||||
qemu_spice_input_init();
|
||||
qemu_spice_audio_init();
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue