4 * Copyright (c) 2007 Red Hat
6 * Permission is hereby granted, free of charge, to any person obtaining a copy
7 * of this software and associated documentation files (the "Software"), to deal
8 * in the Software without restriction, including without limitation the rights
9 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
10 * copies of the Software, and to permit persons to whom the Software is
11 * furnished to do so, subject to the following conditions:
13 * The above copyright notice and this permission notice shall be included in
14 * all copies or substantial portions of the Software.
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
19 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
25 #include "qemu/osdep.h"
27 #include "hw/boards.h"
28 #include "hw/sysbus.h"
29 #include "hw/xen/xen_backend.h"
30 #include "xen_domainbuild.h"
31 #include "sysemu/block-backend.h"
33 #define TYPE_XENSYSDEV "xensysdev"
35 DeviceState
*xen_sysdev
;
37 static void xen_init_pv(MachineState
*machine
)
42 /* Initialize backend core & drivers */
43 if (xen_be_init() != 0) {
44 fprintf(stderr
, "%s: xen backend core setup failed\n", __FUNCTION__
);
50 /* nothing to do, xend handles everything */
52 #ifdef CONFIG_XEN_PV_DOMAIN_BUILD
54 const char *kernel_filename
= machine
->kernel_filename
;
55 const char *kernel_cmdline
= machine
->kernel_cmdline
;
56 const char *initrd_filename
= machine
->initrd_filename
;
57 if (xen_domain_build_pv(kernel_filename
, initrd_filename
,
58 kernel_cmdline
) < 0) {
59 fprintf(stderr
, "xen pv domain creation failed\n");
66 fprintf(stderr
, "xen emulation not implemented (yet)\n");
70 fprintf(stderr
, "unhandled xen_mode %d\n", xen_mode
);
75 xen_sysdev
= qdev_create(NULL
, TYPE_XENSYSDEV
);
76 qdev_init_nofail(xen_sysdev
);
78 xen_be_register("console", &xen_console_ops
);
79 xen_be_register("vkbd", &xen_kbdmouse_ops
);
80 xen_be_register("vfb", &xen_framebuffer_ops
);
81 xen_be_register("qdisk", &xen_blkdev_ops
);
82 xen_be_register("qnic", &xen_netdev_ops
);
83 #ifdef CONFIG_USB_LIBUSB
84 xen_be_register("qusb", &xen_usb_ops
);
87 /* configure framebuffer */
89 xen_config_dev_vfb(0, "vnc");
90 xen_config_dev_vkbd(0);
94 for (i
= 0; i
< 16; i
++) {
95 dinfo
= drive_get(IF_XEN
, 0, i
);
98 xen_config_dev_blk(dinfo
);
102 for (i
= 0; i
< nb_nics
; i
++) {
103 if (!nd_table
[i
].model
|| 0 != strcmp(nd_table
[i
].model
, "xen"))
105 xen_config_dev_nic(nd_table
+ i
);
108 /* config cleanup hook */
109 atexit(xen_config_cleanup
);
111 /* setup framebuffer */
112 xen_init_display(xen_domid
);
115 static int xen_sysdev_init(SysBusDevice
*dev
)
120 static Property xen_sysdev_properties
[] = {
121 {/* end of property list */},
124 static void xen_sysdev_class_init(ObjectClass
*klass
, void *data
)
126 DeviceClass
*dc
= DEVICE_CLASS(klass
);
127 SysBusDeviceClass
*k
= SYS_BUS_DEVICE_CLASS(klass
);
129 k
->init
= xen_sysdev_init
;
130 dc
->props
= xen_sysdev_properties
;
133 static const TypeInfo xensysdev_info
= {
134 .name
= TYPE_XENSYSDEV
,
135 .parent
= TYPE_SYS_BUS_DEVICE
,
136 .instance_size
= sizeof(SysBusDevice
),
137 .class_init
= xen_sysdev_class_init
,
140 static void xenpv_register_types(void)
142 type_register_static(&xensysdev_info
);
145 type_init(xenpv_register_types
);
147 static void xenpv_machine_init(MachineClass
*mc
)
149 mc
->desc
= "Xen Para-virtualized PC";
150 mc
->init
= xen_init_pv
;
152 mc
->default_machine_opts
= "accel=xen";
155 DEFINE_MACHINE("xenpv", xenpv_machine_init
)