mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-04 08:13:54 -06:00
add Win32 IPI service
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com> Signed-off-by: Blue Swirl <blauwirbel@gmail.com>
This commit is contained in:
parent
b55c22c65b
commit
cc015e9a5d
3 changed files with 22 additions and 13 deletions
25
cpus.c
25
cpus.c
|
@ -854,13 +854,32 @@ static void *qemu_tcg_cpu_thread_fn(void *arg)
|
|||
return NULL;
|
||||
}
|
||||
|
||||
static void qemu_cpu_kick_thread(CPUState *env)
|
||||
{
|
||||
#ifndef _WIN32
|
||||
int err;
|
||||
|
||||
err = pthread_kill(env->thread->thread, SIG_IPI);
|
||||
if (err) {
|
||||
fprintf(stderr, "qemu:%s: %s", __func__, strerror(err));
|
||||
exit(1);
|
||||
}
|
||||
#else /* _WIN32 */
|
||||
if (!qemu_cpu_is_self(env)) {
|
||||
SuspendThread(env->thread->thread);
|
||||
cpu_signal(0);
|
||||
ResumeThread(env->thread->thread);
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
void qemu_cpu_kick(void *_env)
|
||||
{
|
||||
CPUState *env = _env;
|
||||
|
||||
qemu_cond_broadcast(env->halt_cond);
|
||||
if (!env->thread_kicked) {
|
||||
qemu_thread_signal(env->thread, SIG_IPI);
|
||||
qemu_cpu_kick_thread(env);
|
||||
env->thread_kicked = true;
|
||||
}
|
||||
}
|
||||
|
@ -871,7 +890,7 @@ void qemu_cpu_kick_self(void)
|
|||
assert(cpu_single_env);
|
||||
|
||||
if (!cpu_single_env->thread_kicked) {
|
||||
qemu_thread_signal(cpu_single_env->thread, SIG_IPI);
|
||||
qemu_cpu_kick_thread(cpu_single_env);
|
||||
cpu_single_env->thread_kicked = true;
|
||||
}
|
||||
#else
|
||||
|
@ -893,7 +912,7 @@ void qemu_mutex_lock_iothread(void)
|
|||
} else {
|
||||
qemu_mutex_lock(&qemu_fair_mutex);
|
||||
if (qemu_mutex_trylock(&qemu_global_mutex)) {
|
||||
qemu_thread_signal(tcg_cpu_thread, SIG_IPI);
|
||||
qemu_cpu_kick_thread(first_cpu);
|
||||
qemu_mutex_lock(&qemu_global_mutex);
|
||||
}
|
||||
qemu_mutex_unlock(&qemu_fair_mutex);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue