merge all signal initialization with qemu_signalfd_init, rename
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com> Signed-off-by: Blue Swirl <blauwirbel@gmail.com>
This commit is contained in:
parent
8cf3f22b77
commit
712ae48084
87
cpus.c
87
cpus.c
@ -346,11 +346,37 @@ static void sigfd_handler(void *opaque)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int qemu_signalfd_init(sigset_t mask)
|
static int qemu_signal_init(void)
|
||||||
{
|
{
|
||||||
int sigfd;
|
int sigfd;
|
||||||
|
sigset_t set;
|
||||||
|
|
||||||
sigfd = qemu_signalfd(&mask);
|
#ifdef CONFIG_IOTHREAD
|
||||||
|
/* SIGUSR2 used by posix-aio-compat.c */
|
||||||
|
sigemptyset(&set);
|
||||||
|
sigaddset(&set, SIGUSR2);
|
||||||
|
pthread_sigmask(SIG_UNBLOCK, &set, NULL);
|
||||||
|
|
||||||
|
sigemptyset(&set);
|
||||||
|
sigaddset(&set, SIGIO);
|
||||||
|
sigaddset(&set, SIGALRM);
|
||||||
|
sigaddset(&set, SIG_IPI);
|
||||||
|
sigaddset(&set, SIGBUS);
|
||||||
|
pthread_sigmask(SIG_BLOCK, &set, NULL);
|
||||||
|
#else
|
||||||
|
sigemptyset(&set);
|
||||||
|
sigaddset(&set, SIGBUS);
|
||||||
|
if (kvm_enabled()) {
|
||||||
|
/*
|
||||||
|
* We need to process timer signals synchronously to avoid a race
|
||||||
|
* between exit_request check and KVM vcpu entry.
|
||||||
|
*/
|
||||||
|
sigaddset(&set, SIGIO);
|
||||||
|
sigaddset(&set, SIGALRM);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
sigfd = qemu_signalfd(&set);
|
||||||
if (sigfd == -1) {
|
if (sigfd == -1) {
|
||||||
fprintf(stderr, "failed to create signalfd\n");
|
fprintf(stderr, "failed to create signalfd\n");
|
||||||
return -errno;
|
return -errno;
|
||||||
@ -438,6 +464,12 @@ static void qemu_event_increment(void)
|
|||||||
static void qemu_kvm_eat_signals(CPUState *env)
|
static void qemu_kvm_eat_signals(CPUState *env)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int qemu_signal_init(void)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
|
|
||||||
#ifndef CONFIG_IOTHREAD
|
#ifndef CONFIG_IOTHREAD
|
||||||
@ -471,39 +503,14 @@ static void qemu_kvm_init_cpu_signals(CPUState *env)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef _WIN32
|
|
||||||
static sigset_t block_synchronous_signals(void)
|
|
||||||
{
|
|
||||||
sigset_t set;
|
|
||||||
|
|
||||||
sigemptyset(&set);
|
|
||||||
sigaddset(&set, SIGBUS);
|
|
||||||
if (kvm_enabled()) {
|
|
||||||
/*
|
|
||||||
* We need to process timer signals synchronously to avoid a race
|
|
||||||
* between exit_request check and KVM vcpu entry.
|
|
||||||
*/
|
|
||||||
sigaddset(&set, SIGIO);
|
|
||||||
sigaddset(&set, SIGALRM);
|
|
||||||
}
|
|
||||||
|
|
||||||
return set;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
int qemu_init_main_loop(void)
|
int qemu_init_main_loop(void)
|
||||||
{
|
{
|
||||||
#ifndef _WIN32
|
|
||||||
sigset_t blocked_signals;
|
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
blocked_signals = block_synchronous_signals();
|
ret = qemu_signal_init();
|
||||||
|
|
||||||
ret = qemu_signalfd_init(blocked_signals);
|
|
||||||
if (ret) {
|
if (ret) {
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
qemu_init_sigbus();
|
qemu_init_sigbus();
|
||||||
|
|
||||||
@ -651,35 +658,13 @@ static void qemu_tcg_init_cpu_signals(void)
|
|||||||
pthread_sigmask(SIG_UNBLOCK, &set, NULL);
|
pthread_sigmask(SIG_UNBLOCK, &set, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
static sigset_t block_io_signals(void)
|
|
||||||
{
|
|
||||||
sigset_t set;
|
|
||||||
|
|
||||||
/* SIGUSR2 used by posix-aio-compat.c */
|
|
||||||
sigemptyset(&set);
|
|
||||||
sigaddset(&set, SIGUSR2);
|
|
||||||
pthread_sigmask(SIG_UNBLOCK, &set, NULL);
|
|
||||||
|
|
||||||
sigemptyset(&set);
|
|
||||||
sigaddset(&set, SIGIO);
|
|
||||||
sigaddset(&set, SIGALRM);
|
|
||||||
sigaddset(&set, SIG_IPI);
|
|
||||||
sigaddset(&set, SIGBUS);
|
|
||||||
pthread_sigmask(SIG_BLOCK, &set, NULL);
|
|
||||||
|
|
||||||
return set;
|
|
||||||
}
|
|
||||||
|
|
||||||
int qemu_init_main_loop(void)
|
int qemu_init_main_loop(void)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
sigset_t blocked_signals;
|
|
||||||
|
|
||||||
qemu_init_sigbus();
|
qemu_init_sigbus();
|
||||||
|
|
||||||
blocked_signals = block_io_signals();
|
ret = qemu_signal_init();
|
||||||
|
|
||||||
ret = qemu_signalfd_init(blocked_signals);
|
|
||||||
if (ret) {
|
if (ret) {
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user