Merge remote-tracking branch 'spice/spice.v37' into staging
Conflicts: vl.c
This commit is contained in:
commit
ac779fe233
2
configure
vendored
2
configure
vendored
@ -2414,7 +2414,7 @@ int main(void) { spice_server_new(); return 0; }
|
|||||||
EOF
|
EOF
|
||||||
spice_cflags=$($pkg_config --cflags spice-protocol spice-server 2>/dev/null)
|
spice_cflags=$($pkg_config --cflags spice-protocol spice-server 2>/dev/null)
|
||||||
spice_libs=$($pkg_config --libs spice-protocol spice-server 2>/dev/null)
|
spice_libs=$($pkg_config --libs spice-protocol spice-server 2>/dev/null)
|
||||||
if $pkg_config --atleast-version=0.5.3 spice-server >/dev/null 2>&1 && \
|
if $pkg_config --atleast-version=0.6.0 spice-server >/dev/null 2>&1 && \
|
||||||
compile_prog "$spice_cflags" "$spice_libs" ; then
|
compile_prog "$spice_cflags" "$spice_libs" ; then
|
||||||
spice="yes"
|
spice="yes"
|
||||||
libs_softmmu="$libs_softmmu $spice_libs"
|
libs_softmmu="$libs_softmmu $spice_libs"
|
||||||
|
4
hw/qxl.c
4
hw/qxl.c
@ -357,7 +357,9 @@ static int interface_get_command(QXLInstance *sin, struct QXLCommandExt *ext)
|
|||||||
ret = true;
|
ret = true;
|
||||||
}
|
}
|
||||||
qemu_mutex_unlock(&qxl->ssd.lock);
|
qemu_mutex_unlock(&qxl->ssd.lock);
|
||||||
qxl_log_command(qxl, "vga", ext);
|
if (ret) {
|
||||||
|
qxl_log_command(qxl, "vga", ext);
|
||||||
|
}
|
||||||
return ret;
|
return ret;
|
||||||
case QXL_MODE_COMPAT:
|
case QXL_MODE_COMPAT:
|
||||||
case QXL_MODE_NATIVE:
|
case QXL_MODE_NATIVE:
|
||||||
|
@ -306,7 +306,7 @@ static QemuOptsList qemu_trace_opts = {
|
|||||||
.name = "file",
|
.name = "file",
|
||||||
.type = QEMU_OPT_STRING,
|
.type = QEMU_OPT_STRING,
|
||||||
},
|
},
|
||||||
{ /* end if list */ }
|
{ /* end of list */ }
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
@ -384,6 +384,12 @@ QemuOptsList qemu_spice_opts = {
|
|||||||
},{
|
},{
|
||||||
.name = "disable-ticketing",
|
.name = "disable-ticketing",
|
||||||
.type = QEMU_OPT_BOOL,
|
.type = QEMU_OPT_BOOL,
|
||||||
|
},{
|
||||||
|
.name = "disable-copy-paste",
|
||||||
|
.type = QEMU_OPT_BOOL,
|
||||||
|
},{
|
||||||
|
.name = "sasl",
|
||||||
|
.type = QEMU_OPT_BOOL,
|
||||||
},{
|
},{
|
||||||
.name = "x509-dir",
|
.name = "x509-dir",
|
||||||
.type = QEMU_OPT_STRING,
|
.type = QEMU_OPT_STRING,
|
||||||
@ -430,7 +436,7 @@ QemuOptsList qemu_spice_opts = {
|
|||||||
.name = "playback-compression",
|
.name = "playback-compression",
|
||||||
.type = QEMU_OPT_BOOL,
|
.type = QEMU_OPT_BOOL,
|
||||||
},
|
},
|
||||||
{ /* end if list */ }
|
{ /* end of list */ }
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -446,7 +452,7 @@ QemuOptsList qemu_option_rom_opts = {
|
|||||||
.name = "romfile",
|
.name = "romfile",
|
||||||
.type = QEMU_OPT_STRING,
|
.type = QEMU_OPT_STRING,
|
||||||
},
|
},
|
||||||
{ /* end if list */ }
|
{ /* end of list */ }
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -714,9 +714,25 @@ Force using the specified IP version.
|
|||||||
@item password=<secret>
|
@item password=<secret>
|
||||||
Set the password you need to authenticate.
|
Set the password you need to authenticate.
|
||||||
|
|
||||||
|
@item sasl
|
||||||
|
Require that the client use SASL to authenticate with the spice.
|
||||||
|
The exact choice of authentication method used is controlled from the
|
||||||
|
system / user's SASL configuration file for the 'qemu' service. This
|
||||||
|
is typically found in /etc/sasl2/qemu.conf. If running QEMU as an
|
||||||
|
unprivileged user, an environment variable SASL_CONF_PATH can be used
|
||||||
|
to make it search alternate locations for the service config.
|
||||||
|
While some SASL auth methods can also provide data encryption (eg GSSAPI),
|
||||||
|
it is recommended that SASL always be combined with the 'tls' and
|
||||||
|
'x509' settings to enable use of SSL and server certificates. This
|
||||||
|
ensures a data encryption preventing compromise of authentication
|
||||||
|
credentials.
|
||||||
|
|
||||||
@item disable-ticketing
|
@item disable-ticketing
|
||||||
Allow client connects without authentication.
|
Allow client connects without authentication.
|
||||||
|
|
||||||
|
@item disable-copy-paste
|
||||||
|
Disable copy paste between the client and the guest.
|
||||||
|
|
||||||
@item tls-port=<nr>
|
@item tls-port=<nr>
|
||||||
Set the TCP port spice is listening on for encrypted channels.
|
Set the TCP port spice is listening on for encrypted channels.
|
||||||
|
|
||||||
|
@ -36,14 +36,13 @@ static int vmc_write(SpiceCharDeviceInstance *sin, const uint8_t *buf, int len)
|
|||||||
|
|
||||||
while (len > 0) {
|
while (len > 0) {
|
||||||
last_out = MIN(len, VMC_MAX_HOST_WRITE);
|
last_out = MIN(len, VMC_MAX_HOST_WRITE);
|
||||||
qemu_chr_read(scd->chr, p, last_out);
|
if (qemu_chr_can_read(scd->chr) < last_out) {
|
||||||
if (last_out > 0) {
|
|
||||||
out += last_out;
|
|
||||||
len -= last_out;
|
|
||||||
p += last_out;
|
|
||||||
} else {
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
qemu_chr_read(scd->chr, p, last_out);
|
||||||
|
out += last_out;
|
||||||
|
len -= last_out;
|
||||||
|
p += last_out;
|
||||||
}
|
}
|
||||||
|
|
||||||
dprintf(scd, 3, "%s: %lu/%zd\n", __func__, out, len + out);
|
dprintf(scd, 3, "%s: %lu/%zd\n", __func__, out, len + out);
|
||||||
|
@ -299,8 +299,6 @@ static int parse_name(const char *string, const char *optname,
|
|||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if SPICE_SERVER_VERSION >= 0x000600 /* 0.6.0 */
|
|
||||||
|
|
||||||
static const char *stream_video_names[] = {
|
static const char *stream_video_names[] = {
|
||||||
[ SPICE_STREAM_VIDEO_OFF ] = "off",
|
[ SPICE_STREAM_VIDEO_OFF ] = "off",
|
||||||
[ SPICE_STREAM_VIDEO_ALL ] = "all",
|
[ SPICE_STREAM_VIDEO_ALL ] = "all",
|
||||||
@ -309,8 +307,6 @@ static const char *stream_video_names[] = {
|
|||||||
#define parse_stream_video(_name) \
|
#define parse_stream_video(_name) \
|
||||||
name2enum(_name, stream_video_names, ARRAY_SIZE(stream_video_names))
|
name2enum(_name, stream_video_names, ARRAY_SIZE(stream_video_names))
|
||||||
|
|
||||||
#endif /* >= 0.6.0 */
|
|
||||||
|
|
||||||
static const char *compression_names[] = {
|
static const char *compression_names[] = {
|
||||||
[ SPICE_IMAGE_COMPRESS_OFF ] = "off",
|
[ SPICE_IMAGE_COMPRESS_OFF ] = "off",
|
||||||
[ SPICE_IMAGE_COMPRESS_AUTO_GLZ ] = "auto_glz",
|
[ SPICE_IMAGE_COMPRESS_AUTO_GLZ ] = "auto_glz",
|
||||||
@ -549,11 +545,29 @@ void qemu_spice_init(void)
|
|||||||
if (password) {
|
if (password) {
|
||||||
spice_server_set_ticket(spice_server, password, 0, 0, 0);
|
spice_server_set_ticket(spice_server, password, 0, 0, 0);
|
||||||
}
|
}
|
||||||
|
if (qemu_opt_get_bool(opts, "sasl", 0)) {
|
||||||
|
#if SPICE_SERVER_VERSION >= 0x000900 /* 0.9.0 */
|
||||||
|
if (spice_server_set_sasl_appname(spice_server, "qemu") == -1 ||
|
||||||
|
spice_server_set_sasl(spice_server, 1) == -1) {
|
||||||
|
fprintf(stderr, "spice: failed to enable sasl\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
fprintf(stderr, "spice: sasl is not available (spice >= 0.9 required)\n");
|
||||||
|
exit(1);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
if (qemu_opt_get_bool(opts, "disable-ticketing", 0)) {
|
if (qemu_opt_get_bool(opts, "disable-ticketing", 0)) {
|
||||||
auth = "none";
|
auth = "none";
|
||||||
spice_server_set_noauth(spice_server);
|
spice_server_set_noauth(spice_server);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if SPICE_SERVER_VERSION >= 0x000801
|
||||||
|
if (qemu_opt_get_bool(opts, "disable-copy-paste", 0)) {
|
||||||
|
spice_server_set_agent_copypaste(spice_server, false);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
compression = SPICE_IMAGE_COMPRESS_AUTO_GLZ;
|
compression = SPICE_IMAGE_COMPRESS_AUTO_GLZ;
|
||||||
str = qemu_opt_get(opts, "image-compression");
|
str = qemu_opt_get(opts, "image-compression");
|
||||||
if (str) {
|
if (str) {
|
||||||
@ -575,8 +589,6 @@ void qemu_spice_init(void)
|
|||||||
}
|
}
|
||||||
spice_server_set_zlib_glz_compression(spice_server, wan_compr);
|
spice_server_set_zlib_glz_compression(spice_server, wan_compr);
|
||||||
|
|
||||||
#if SPICE_SERVER_VERSION >= 0x000600 /* 0.6.0 */
|
|
||||||
|
|
||||||
str = qemu_opt_get(opts, "streaming-video");
|
str = qemu_opt_get(opts, "streaming-video");
|
||||||
if (str) {
|
if (str) {
|
||||||
int streaming_video = parse_stream_video(str);
|
int streaming_video = parse_stream_video(str);
|
||||||
@ -588,8 +600,6 @@ void qemu_spice_init(void)
|
|||||||
spice_server_set_playback_compression
|
spice_server_set_playback_compression
|
||||||
(spice_server, qemu_opt_get_bool(opts, "playback-compression", 1));
|
(spice_server, qemu_opt_get_bool(opts, "playback-compression", 1));
|
||||||
|
|
||||||
#endif /* >= 0.6.0 */
|
|
||||||
|
|
||||||
qemu_opt_foreach(opts, add_channel, NULL, 0);
|
qemu_opt_foreach(opts, add_channel, NULL, 0);
|
||||||
|
|
||||||
spice_server_init(spice_server, &core_interface);
|
spice_server_init(spice_server, &core_interface);
|
||||||
|
1
vl.c
1
vl.c
@ -290,6 +290,7 @@ static struct {
|
|||||||
{ .driver = "cirrus-vga", .flag = &default_vga },
|
{ .driver = "cirrus-vga", .flag = &default_vga },
|
||||||
{ .driver = "vmware-svga", .flag = &default_vga },
|
{ .driver = "vmware-svga", .flag = &default_vga },
|
||||||
{ .driver = "isa-vga", .flag = &default_vga },
|
{ .driver = "isa-vga", .flag = &default_vga },
|
||||||
|
{ .driver = "qxl-vga", .flag = &default_vga },
|
||||||
};
|
};
|
||||||
|
|
||||||
static int default_driver_check(QemuOpts *opts, void *opaque)
|
static int default_driver_check(QemuOpts *opts, void *opaque)
|
||||||
|
Loading…
Reference in New Issue
Block a user