fixes for 2.9-rc1, plus removal of -mno-cygwin references
-----BEGIN PGP SIGNATURE----- Version: GnuPG v2 iQExBAABCAAbBQJYz7wTFBxwYm9uemluaUByZWRoYXQuY29tAAoJEL/70l94x66D AYwH/ip/ZIxsAEKMpQnGfwgHiLgGvFD+10wJECXLChyzcQLqqs4KingQEHMh6o9f Y1DTMyJBDk65k5zSEVx7nqisI82SUlvwOZJpVqCfF2AbY/HR+a+tUOp9njuz6EDh ZVSAnvIDfZC1P2BcXOPzEySXBNCZcZG0iHO9U4eobGAxRGVUs/8a8qHTuRVc2Mwg bT7lxLzE4chgQ1jFu2D7TzjwkFvAYeUHWdj2rl+U3KwEF9pUm0hAEfvymEP4d6hE hPqcE2X9W42n8wbxL7edI0EVZnc+bltfakioy+BxgrkxEZFLgMmKsUtNOuQ7sUdT VvQ3Zbw2solv6ltOqCbexLWueM4= =Vli2 -----END PGP SIGNATURE----- Merge remote-tracking branch 'remotes/bonzini/tags/for-upstream' into staging fixes for 2.9-rc1, plus removal of -mno-cygwin references # gpg: Signature made Mon 20 Mar 2017 11:25:07 GMT # gpg: using RSA key 0xBFFBD25F78C7AE83 # gpg: Good signature from "Paolo Bonzini <bonzini@gnu.org>" # gpg: aka "Paolo Bonzini <pbonzini@redhat.com>" # Primary key fingerprint: 46F5 9FBD 57D6 12E7 BFD4 E2F7 7E15 100C CD36 69B1 # Subkey fingerprint: F133 3857 4B66 2389 866C 7682 BFFB D25F 78C7 AE83 * remotes/bonzini/tags/for-upstream: hax: fix breakage in locking configure: remove Cygwin xen: do not build backends for targets that do not support xen qemu-ga: obey LISTEN_PID when using systemd socket activation Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
commit
940a8ce075
1
Makefile
1
Makefile
@ -26,6 +26,7 @@ endif
|
||||
|
||||
CONFIG_SOFTMMU := $(if $(filter %-softmmu,$(TARGET_DIRS)),y)
|
||||
CONFIG_USER_ONLY := $(if $(filter %-user,$(TARGET_DIRS)),y)
|
||||
CONFIG_XEN := $(CONFIG_XEN_BACKEND)
|
||||
CONFIG_ALL=y
|
||||
-include config-all-devices.mak
|
||||
-include config-all-disas.mak
|
||||
|
3
cpus.c
3
cpus.c
@ -1344,8 +1344,9 @@ static void *qemu_hax_cpu_thread_fn(void *arg)
|
||||
{
|
||||
CPUState *cpu = arg;
|
||||
int r;
|
||||
|
||||
qemu_mutex_lock_iothread();
|
||||
qemu_thread_get_self(cpu->thread);
|
||||
qemu_mutex_lock(&qemu_global_mutex);
|
||||
|
||||
cpu->thread_id = qemu_get_thread_id();
|
||||
cpu->created = true;
|
||||
|
@ -4,7 +4,7 @@ common-obj-$(CONFIG_SSI_M25P80) += m25p80.o
|
||||
common-obj-$(CONFIG_NAND) += nand.o
|
||||
common-obj-$(CONFIG_PFLASH_CFI01) += pflash_cfi01.o
|
||||
common-obj-$(CONFIG_PFLASH_CFI02) += pflash_cfi02.o
|
||||
common-obj-$(CONFIG_XEN_BACKEND) += xen_disk.o
|
||||
common-obj-$(CONFIG_XEN) += xen_disk.o
|
||||
common-obj-$(CONFIG_ECC) += ecc.o
|
||||
common-obj-$(CONFIG_ONENAND) += onenand.o
|
||||
common-obj-$(CONFIG_NVME_PCI) += nvme.o
|
||||
|
@ -7,7 +7,7 @@ common-obj-$(CONFIG_SERIAL_ISA) += serial-isa.o
|
||||
common-obj-$(CONFIG_SERIAL_PCI) += serial-pci.o
|
||||
common-obj-$(CONFIG_VIRTIO) += virtio-console.o
|
||||
common-obj-$(CONFIG_XILINX) += xilinx_uartlite.o
|
||||
common-obj-$(CONFIG_XEN_BACKEND) += xen_console.o
|
||||
common-obj-$(CONFIG_XEN) += xen_console.o
|
||||
common-obj-$(CONFIG_CADENCE) += cadence_uart.o
|
||||
|
||||
obj-$(CONFIG_EXYNOS4) += exynos4210_uart.o
|
||||
|
@ -5,7 +5,7 @@ common-obj-$(CONFIG_JAZZ_LED) += jazz_led.o
|
||||
common-obj-$(CONFIG_PL110) += pl110.o
|
||||
common-obj-$(CONFIG_SSD0303) += ssd0303.o
|
||||
common-obj-$(CONFIG_SSD0323) += ssd0323.o
|
||||
common-obj-$(CONFIG_XEN_BACKEND) += xenfb.o
|
||||
common-obj-$(CONFIG_XEN) += xenfb.o
|
||||
|
||||
common-obj-$(CONFIG_VGA_PCI) += vga-pci.o
|
||||
common-obj-$(CONFIG_VGA_ISA) += vga-isa.o
|
||||
|
@ -1,5 +1,5 @@
|
||||
common-obj-$(CONFIG_DP8393X) += dp8393x.o
|
||||
common-obj-$(CONFIG_XEN_BACKEND) += xen_nic.o
|
||||
common-obj-$(CONFIG_XEN) += xen_nic.o
|
||||
|
||||
# PCI network cards
|
||||
common-obj-$(CONFIG_NE2000_PCI) += ne2000.o
|
||||
|
@ -40,5 +40,5 @@ common-obj-$(CONFIG_USB_REDIR) += redirect.o quirks.o
|
||||
common-obj-y += $(patsubst %,host-%.o,$(HOST_USB))
|
||||
|
||||
ifeq ($(CONFIG_USB_LIBUSB),y)
|
||||
common-obj-$(CONFIG_XEN_BACKEND) += xen-usb.o
|
||||
common-obj-$(CONFIG_XEN) += xen-usb.o
|
||||
endif
|
||||
|
@ -1,5 +1,5 @@
|
||||
# xen backend driver support
|
||||
common-obj-$(CONFIG_XEN_BACKEND) += xen_backend.o xen_devconfig.o xen_pvdev.o
|
||||
common-obj-$(CONFIG_XEN) += xen_backend.o xen_devconfig.o xen_pvdev.o
|
||||
|
||||
obj-$(CONFIG_XEN_PCI_PASSTHROUGH) += xen-host-pci-device.o
|
||||
obj-$(CONFIG_XEN_PCI_PASSTHROUGH) += xen_pt.o xen_pt_config_init.o xen_pt_graphics.o xen_pt_msi.o
|
||||
|
26
include/qemu/systemd.h
Normal file
26
include/qemu/systemd.h
Normal file
@ -0,0 +1,26 @@
|
||||
/*
|
||||
* systemd socket activation support
|
||||
*
|
||||
* Copyright 2017 Red Hat, Inc. and/or its affiliates
|
||||
*
|
||||
* Authors:
|
||||
* Richard W.M. Jones <rjones@redhat.com>
|
||||
*
|
||||
* This work is licensed under the terms of the GNU GPL, version 2 or later.
|
||||
* See the COPYING file in the top-level directory.
|
||||
*/
|
||||
|
||||
#ifndef QEMU_SYSTEMD_H
|
||||
#define QEMU_SYSTEMD_H 1
|
||||
|
||||
#define FIRST_SOCKET_ACTIVATION_FD 3 /* defined by systemd ABI */
|
||||
|
||||
/*
|
||||
* Check if socket activation was requested via use of the
|
||||
* LISTEN_FDS and LISTEN_PID environment variables.
|
||||
*
|
||||
* Returns 0 if no socket activation, or the number of FDs.
|
||||
*/
|
||||
unsigned int check_socket_activation(void);
|
||||
|
||||
#endif
|
100
qemu-nbd.c
100
qemu-nbd.c
@ -28,6 +28,7 @@
|
||||
#include "qemu/config-file.h"
|
||||
#include "qemu/bswap.h"
|
||||
#include "qemu/log.h"
|
||||
#include "qemu/systemd.h"
|
||||
#include "block/snapshot.h"
|
||||
#include "qapi/util.h"
|
||||
#include "qapi/qmp/qstring.h"
|
||||
@ -474,98 +475,6 @@ static void setup_address_and_port(const char **address, const char **port)
|
||||
}
|
||||
}
|
||||
|
||||
#define FIRST_SOCKET_ACTIVATION_FD 3 /* defined by systemd ABI */
|
||||
|
||||
#ifndef _WIN32
|
||||
/*
|
||||
* Check if socket activation was requested via use of the
|
||||
* LISTEN_FDS and LISTEN_PID environment variables.
|
||||
*
|
||||
* Returns 0 if no socket activation, or the number of FDs.
|
||||
*/
|
||||
static unsigned int check_socket_activation(void)
|
||||
{
|
||||
const char *s;
|
||||
unsigned long pid;
|
||||
unsigned long nr_fds;
|
||||
unsigned int i;
|
||||
int fd;
|
||||
int err;
|
||||
|
||||
s = getenv("LISTEN_PID");
|
||||
if (s == NULL) {
|
||||
return 0;
|
||||
}
|
||||
err = qemu_strtoul(s, NULL, 10, &pid);
|
||||
if (err) {
|
||||
if (verbose) {
|
||||
fprintf(stderr, "malformed %s environment variable (ignored)\n",
|
||||
"LISTEN_PID");
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
if (pid != getpid()) {
|
||||
if (verbose) {
|
||||
fprintf(stderr, "%s was not for us (ignored)\n",
|
||||
"LISTEN_PID");
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
s = getenv("LISTEN_FDS");
|
||||
if (s == NULL) {
|
||||
return 0;
|
||||
}
|
||||
err = qemu_strtoul(s, NULL, 10, &nr_fds);
|
||||
if (err) {
|
||||
if (verbose) {
|
||||
fprintf(stderr, "malformed %s environment variable (ignored)\n",
|
||||
"LISTEN_FDS");
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
assert(nr_fds <= UINT_MAX);
|
||||
|
||||
/* A limitation of current qemu-nbd is that it can only listen on
|
||||
* a single socket. When that limitation is lifted, we can change
|
||||
* this function to allow LISTEN_FDS > 1, and remove the assertion
|
||||
* in the main function below.
|
||||
*/
|
||||
if (nr_fds > 1) {
|
||||
error_report("qemu-nbd does not support socket activation with %s > 1",
|
||||
"LISTEN_FDS");
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
/* So these are not passed to any child processes we might start. */
|
||||
unsetenv("LISTEN_FDS");
|
||||
unsetenv("LISTEN_PID");
|
||||
|
||||
/* So the file descriptors don't leak into child processes. */
|
||||
for (i = 0; i < nr_fds; ++i) {
|
||||
fd = FIRST_SOCKET_ACTIVATION_FD + i;
|
||||
if (fcntl(fd, F_SETFD, FD_CLOEXEC) == -1) {
|
||||
/* If we cannot set FD_CLOEXEC then it probably means the file
|
||||
* descriptor is invalid, so socket activation has gone wrong
|
||||
* and we should exit.
|
||||
*/
|
||||
error_report("Socket activation failed: "
|
||||
"invalid file descriptor fd = %d: %m",
|
||||
fd);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
}
|
||||
|
||||
return (unsigned int) nr_fds;
|
||||
}
|
||||
|
||||
#else /* !_WIN32 */
|
||||
static unsigned int check_socket_activation(void)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
||||
/*
|
||||
* Check socket parameters compatibility when socket activation is used.
|
||||
*/
|
||||
@ -892,6 +801,13 @@ int main(int argc, char **argv)
|
||||
error_report("%s", err_msg);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
/* qemu-nbd can only listen on a single socket. */
|
||||
if (socket_activation > 1) {
|
||||
error_report("qemu-nbd does not support socket activation with %s > 1",
|
||||
"LISTEN_FDS");
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
}
|
||||
|
||||
if (tlscredsid) {
|
||||
|
51
qga/main.c
51
qga/main.c
@ -29,6 +29,7 @@
|
||||
#include "qemu/bswap.h"
|
||||
#include "qemu/help_option.h"
|
||||
#include "qemu/sockets.h"
|
||||
#include "qemu/systemd.h"
|
||||
#ifdef _WIN32
|
||||
#include "qga/service-win32.h"
|
||||
#include "qga/vss-win32.h"
|
||||
@ -186,37 +187,6 @@ void reopen_fd_to_null(int fd)
|
||||
}
|
||||
#endif
|
||||
|
||||
/**
|
||||
* get_listen_fd:
|
||||
* @consume: true to prevent future calls from succeeding
|
||||
*
|
||||
* Fetch a listen file descriptor that was passed via systemd socket
|
||||
* activation. Use @consume to prevent child processes from thinking a file
|
||||
* descriptor was passed.
|
||||
*
|
||||
* Returns: file descriptor or -1 if no fd was passed
|
||||
*/
|
||||
static int get_listen_fd(bool consume)
|
||||
{
|
||||
#ifdef _WIN32
|
||||
return -1; /* no fd passing expected, unsetenv(3) not available */
|
||||
#else
|
||||
const char *listen_fds = getenv("LISTEN_FDS");
|
||||
int fd = STDERR_FILENO + 1;
|
||||
|
||||
if (!listen_fds || strcmp(listen_fds, "1") != 0) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (consume) {
|
||||
unsetenv("LISTEN_FDS");
|
||||
}
|
||||
|
||||
qemu_set_cloexec(fd);
|
||||
return fd;
|
||||
#endif /* !_WIN32 */
|
||||
}
|
||||
|
||||
static void usage(const char *cmd)
|
||||
{
|
||||
printf(
|
||||
@ -1251,7 +1221,7 @@ static bool check_is_frozen(GAState *s)
|
||||
return false;
|
||||
}
|
||||
|
||||
static int run_agent(GAState *s, GAConfig *config)
|
||||
static int run_agent(GAState *s, GAConfig *config, int socket_activation)
|
||||
{
|
||||
ga_state = s;
|
||||
|
||||
@ -1333,7 +1303,7 @@ static int run_agent(GAState *s, GAConfig *config)
|
||||
s->main_loop = g_main_loop_new(NULL, false);
|
||||
|
||||
if (!channel_init(ga_state, config->method, config->channel_path,
|
||||
get_listen_fd(true))) {
|
||||
socket_activation ? FIRST_SOCKET_ACTIVATION_FD : -1)) {
|
||||
g_critical("failed to initialize guest agent channel");
|
||||
return EXIT_FAILURE;
|
||||
}
|
||||
@ -1357,7 +1327,7 @@ int main(int argc, char **argv)
|
||||
int ret = EXIT_SUCCESS;
|
||||
GAState *s = g_new0(GAState, 1);
|
||||
GAConfig *config = g_new0(GAConfig, 1);
|
||||
int listen_fd;
|
||||
int socket_activation;
|
||||
|
||||
config->log_level = G_LOG_LEVEL_ERROR | G_LOG_LEVEL_CRITICAL;
|
||||
|
||||
@ -1379,8 +1349,13 @@ int main(int argc, char **argv)
|
||||
config->method = g_strdup("virtio-serial");
|
||||
}
|
||||
|
||||
listen_fd = get_listen_fd(false);
|
||||
if (listen_fd >= 0) {
|
||||
socket_activation = check_socket_activation();
|
||||
if (socket_activation > 1) {
|
||||
g_critical("qemu-ga only supports listening on one socket");
|
||||
ret = EXIT_FAILURE;
|
||||
goto end;
|
||||
}
|
||||
if (socket_activation) {
|
||||
SocketAddress *addr;
|
||||
|
||||
g_free(config->method);
|
||||
@ -1388,7 +1363,7 @@ int main(int argc, char **argv)
|
||||
config->method = NULL;
|
||||
config->channel_path = NULL;
|
||||
|
||||
addr = socket_local_address(listen_fd, NULL);
|
||||
addr = socket_local_address(FIRST_SOCKET_ACTIVATION_FD, NULL);
|
||||
if (addr) {
|
||||
if (addr->type == SOCKET_ADDRESS_KIND_UNIX) {
|
||||
config->method = g_strdup("unix-listen");
|
||||
@ -1433,7 +1408,7 @@ int main(int argc, char **argv)
|
||||
goto end;
|
||||
}
|
||||
|
||||
ret = run_agent(s, config);
|
||||
ret = run_agent(s, config, socket_activation);
|
||||
|
||||
end:
|
||||
if (s->command_state) {
|
||||
|
@ -42,3 +42,4 @@ util-obj-y += log.o
|
||||
util-obj-y += qdist.o
|
||||
util-obj-y += qht.o
|
||||
util-obj-y += range.o
|
||||
util-obj-y += systemd.o
|
||||
|
77
util/systemd.c
Normal file
77
util/systemd.c
Normal file
@ -0,0 +1,77 @@
|
||||
/*
|
||||
* systemd socket activation support
|
||||
*
|
||||
* Copyright 2017 Red Hat, Inc. and/or its affiliates
|
||||
*
|
||||
* Authors:
|
||||
* Richard W.M. Jones <rjones@redhat.com>
|
||||
*
|
||||
* This work is licensed under the terms of the GNU GPL, version 2 or later.
|
||||
* See the COPYING file in the top-level directory.
|
||||
*/
|
||||
|
||||
#include "qemu/osdep.h"
|
||||
#include "qemu/systemd.h"
|
||||
#include "qemu/cutils.h"
|
||||
#include "qemu/error-report.h"
|
||||
|
||||
#ifndef _WIN32
|
||||
unsigned int check_socket_activation(void)
|
||||
{
|
||||
const char *s;
|
||||
unsigned long pid;
|
||||
unsigned long nr_fds;
|
||||
unsigned int i;
|
||||
int fd;
|
||||
int err;
|
||||
|
||||
s = getenv("LISTEN_PID");
|
||||
if (s == NULL) {
|
||||
return 0;
|
||||
}
|
||||
err = qemu_strtoul(s, NULL, 10, &pid);
|
||||
if (err) {
|
||||
return 0;
|
||||
}
|
||||
if (pid != getpid()) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
s = getenv("LISTEN_FDS");
|
||||
if (s == NULL) {
|
||||
return 0;
|
||||
}
|
||||
err = qemu_strtoul(s, NULL, 10, &nr_fds);
|
||||
if (err) {
|
||||
return 0;
|
||||
}
|
||||
assert(nr_fds <= UINT_MAX);
|
||||
|
||||
/* So these are not passed to any child processes we might start. */
|
||||
unsetenv("LISTEN_FDS");
|
||||
unsetenv("LISTEN_PID");
|
||||
|
||||
/* So the file descriptors don't leak into child processes. */
|
||||
for (i = 0; i < nr_fds; ++i) {
|
||||
fd = FIRST_SOCKET_ACTIVATION_FD + i;
|
||||
if (fcntl(fd, F_SETFD, FD_CLOEXEC) == -1) {
|
||||
/* If we cannot set FD_CLOEXEC then it probably means the file
|
||||
* descriptor is invalid, so socket activation has gone wrong
|
||||
* and we should exit.
|
||||
*/
|
||||
error_report("Socket activation failed: "
|
||||
"invalid file descriptor fd = %d: %m",
|
||||
fd);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
}
|
||||
|
||||
return (unsigned int) nr_fds;
|
||||
}
|
||||
|
||||
#else /* !_WIN32 */
|
||||
unsigned int check_socket_activation(void)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
#endif
|
Loading…
Reference in New Issue
Block a user