2e5b09fd0e
Suggested-by: Daniel P. Berrangé <berrange@redhat.com> Signed-off-by: Markus Armbruster <armbru@redhat.com> Message-Id: <20190709152053.16670-2-armbru@redhat.com> Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com> Tested-by: Philippe Mathieu-Daudé <philmd@redhat.com> [Rebased onto merge commit 95a9457fd44; missed instances of qom/cpu.h in comments replaced]
72 lines
1.5 KiB
C
72 lines
1.5 KiB
C
/*
|
|
* QEMU Hardware accelertors support
|
|
*
|
|
* Copyright 2016 Google, Inc.
|
|
*
|
|
* 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_HW_ACCEL_H
|
|
#define QEMU_HW_ACCEL_H
|
|
|
|
#include "hw/core/cpu.h"
|
|
#include "sysemu/hax.h"
|
|
#include "sysemu/kvm.h"
|
|
#include "sysemu/whpx.h"
|
|
|
|
static inline void cpu_synchronize_state(CPUState *cpu)
|
|
{
|
|
if (kvm_enabled()) {
|
|
kvm_cpu_synchronize_state(cpu);
|
|
}
|
|
if (hax_enabled()) {
|
|
hax_cpu_synchronize_state(cpu);
|
|
}
|
|
if (whpx_enabled()) {
|
|
whpx_cpu_synchronize_state(cpu);
|
|
}
|
|
}
|
|
|
|
static inline void cpu_synchronize_post_reset(CPUState *cpu)
|
|
{
|
|
if (kvm_enabled()) {
|
|
kvm_cpu_synchronize_post_reset(cpu);
|
|
}
|
|
if (hax_enabled()) {
|
|
hax_cpu_synchronize_post_reset(cpu);
|
|
}
|
|
if (whpx_enabled()) {
|
|
whpx_cpu_synchronize_post_reset(cpu);
|
|
}
|
|
}
|
|
|
|
static inline void cpu_synchronize_post_init(CPUState *cpu)
|
|
{
|
|
if (kvm_enabled()) {
|
|
kvm_cpu_synchronize_post_init(cpu);
|
|
}
|
|
if (hax_enabled()) {
|
|
hax_cpu_synchronize_post_init(cpu);
|
|
}
|
|
if (whpx_enabled()) {
|
|
whpx_cpu_synchronize_post_init(cpu);
|
|
}
|
|
}
|
|
|
|
static inline void cpu_synchronize_pre_loadvm(CPUState *cpu)
|
|
{
|
|
if (kvm_enabled()) {
|
|
kvm_cpu_synchronize_pre_loadvm(cpu);
|
|
}
|
|
if (hax_enabled()) {
|
|
hax_cpu_synchronize_pre_loadvm(cpu);
|
|
}
|
|
if (whpx_enabled()) {
|
|
whpx_cpu_synchronize_pre_loadvm(cpu);
|
|
}
|
|
}
|
|
|
|
#endif /* QEMU_HW_ACCEL_H */
|