Add bootindex handling into usb storage device.
[qemu/stefanha.git] / hw / xen_machine_pv.c
blob77a34bf111dffedc9c95823b3c694e27d316bdee
1 /*
2 * QEMU Xen PV Machine
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
22 * THE SOFTWARE.
25 #include "hw.h"
26 #include "pc.h"
27 #include "sysemu.h"
28 #include "boards.h"
29 #include "xen_backend.h"
30 #include "xen_domainbuild.h"
31 #include "blockdev.h"
33 static void xen_init_pv(ram_addr_t ram_size,
34 const char *boot_device,
35 const char *kernel_filename,
36 const char *kernel_cmdline,
37 const char *initrd_filename,
38 const char *cpu_model)
40 CPUState *env;
41 DriveInfo *dinfo;
42 int i;
44 /* Initialize a dummy CPU */
45 if (cpu_model == NULL) {
46 #ifdef TARGET_X86_64
47 cpu_model = "qemu64";
48 #else
49 cpu_model = "qemu32";
50 #endif
52 env = cpu_init(cpu_model);
53 env->halted = 1;
55 /* Initialize backend core & drivers */
56 if (xen_be_init() != 0) {
57 fprintf(stderr, "%s: xen backend core setup failed\n", __FUNCTION__);
58 exit(1);
61 switch (xen_mode) {
62 case XEN_ATTACH:
63 /* nothing to do, xend handles everything */
64 break;
65 case XEN_CREATE:
66 if (xen_domain_build_pv(kernel_filename, initrd_filename,
67 kernel_cmdline) < 0) {
68 fprintf(stderr, "xen pv domain creation failed\n");
69 exit(1);
71 break;
72 case XEN_EMULATE:
73 fprintf(stderr, "xen emulation not implemented (yet)\n");
74 exit(1);
75 break;
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);
84 /* configure framebuffer */
85 if (xenfb_enabled) {
86 xen_config_dev_vfb(0, "vnc");
87 xen_config_dev_vkbd(0);
90 /* configure disks */
91 for (i = 0; i < 16; i++) {
92 dinfo = drive_get(IF_XEN, 0, i);
93 if (!dinfo)
94 continue;
95 xen_config_dev_blk(dinfo);
98 /* configure nics */
99 for (i = 0; i < nb_nics; i++) {
100 if (!nd_table[i].model || 0 != strcmp(nd_table[i].model, "xen"))
101 continue;
102 xen_config_dev_nic(nd_table + i);
105 /* config cleanup hook */
106 atexit(xen_config_cleanup);
108 /* setup framebuffer */
109 xen_init_display(xen_domid);
112 static QEMUMachine xenpv_machine = {
113 .name = "xenpv",
114 .desc = "Xen Para-virtualized PC",
115 .init = xen_init_pv,
116 .max_cpus = 1,
119 static void xenpv_machine_init(void)
121 qemu_register_machine(&xenpv_machine);
124 machine_init(xenpv_machine_init);