#include "sysemu/arch_init.h"
#include "hw/i2c/smbus.h"
#include "hw/xen/xen.h"
+#include "hw/xen/xen-legacy-backend.h"
#include "exec/memory.h"
#include "exec/address-spaces.h"
#include "hw/acpi/acpi.h"
pcms->above_4g_mem_size = 0;
pcms->below_4g_mem_size = machine->ram_size;
}
+
+ if (!xen_enabled() && !xen_be_xenstore_open()) {
+ kvm_xen_machine_init();
+ }
}
pc_cpus_init(pcms);
xendev->debug = debug;
xendev->local_port = -1;
- xendev->evtchndev = xenevtchn_open(NULL, 0);
- if (xendev->evtchndev == NULL) {
- xen_pv_printf(NULL, 0, "can't open evtchn device\n");
- qdev_unplug(DEVICE(xendev), NULL);
- return NULL;
+ if (xen_mode != XEN_EMULATE) {
+ xendev->evtchndev = xenevtchn_open(NULL, 0);
+ if (xendev->evtchndev == NULL) {
+ xen_pv_printf(NULL, 0, "can't open evtchn device\n");
+ qdev_unplug(DEVICE(xendev), NULL);
+ return NULL;
+ }
+ qemu_set_cloexec(xenevtchn_fd(xendev->evtchndev));
}
- qemu_set_cloexec(xenevtchn_fd(xendev->evtchndev));
xen_pv_insert_xendev(xendev);
bool kvm_has_x2apic_api(void);
bool kvm_hv_vpindex_settable(void);
+void kvm_xen_machine_init(void);
#endif
#ifndef TARGET_I386_XEN_PROTO_H
#define TARGET_I386_XEN_PROTO_H
+#include "hw/xen/xen-legacy-backend.h"
+
typedef struct XenGrantTable {
unsigned int version;
unsigned int nr_frames;
#include "linux/kvm.h"
#include "exec/address-spaces.h"
#include "cpu.h"
+#include "kvm_i386.h"
#include "xen.h"
#include "trace.h"
#include "xen_evtchn.h"
#include "qapi/error.h"
#include "qom/cpu.h"
#include "hw/xen/xen.h"
-
-
-#define __XEN_INTERFACE_VERSION__ 0x00040400
+#include "hw/xen/xen-legacy-backend.h"
+#include "hw/xen/xen-bus.h"
#include "standard-headers/xen/version.h"
#include "standard-headers/xen/memory.h"
kvm_xen_evtchn_init(xen);
}
+void kvm_xen_machine_init(void)
+{
+ xen_bus_init();
+ xen_be_sysdev_init();
+ xen_be_register_common();
+}
+
int kvm_xen_set_domid(KVMState *kvm_state, XenState *xen)
{
struct kvm_xen_hvm_attr xhd;