2 * Jailhouse, a Linux-based partitioning hypervisor
4 * Test configuration for QEMU VM, 1 GB RAM, 64 MB hypervisor (-8 K ACPI)
6 * qemu-system-x86_64 /path/to/image -m 1G -enable-kvm -smp 4 \
7 * -virtfs local,path=/local/path,security_model=passthrough,mount_tag=host \
8 * -cpu kvm64,-kvm_pv_eoi,-kvm_steal_time,-kvm_asyncpf,-kvmclock,+vmx,+x2apic
10 * Copyright (c) Siemens AG, 2013
13 * Jan Kiszka <jan.kiszka@siemens.com>
15 * This work is licensed under the terms of the GNU GPL, version 2. See
16 * the COPYING file in the top-level directory.
19 #include <linux/types.h>
20 #include <jailhouse/cell-config.h>
22 #define ARRAY_SIZE(a) sizeof(a) / sizeof(a[0])
25 struct jailhouse_system header;
27 struct jailhouse_memory mem_regions[5];
28 struct jailhouse_irqchip irqchips[1];
29 __u8 pio_bitmap[0x2000];
30 struct jailhouse_pci_device pci_devices[9];
31 struct jailhouse_pci_capability pci_caps[3];
32 } __attribute__((packed)) config = {
34 .hypervisor_memory = {
35 .phys_start = 0x3c000000,
36 .size = 0x4000000 - 0x30000,
39 .phys_start = 0x3ffdf000,
42 .platform_info.x86 = {
43 .pm_timer_address = 0x608,
46 .name = "QEMU Linux VM",
48 .cpu_set_size = sizeof(config.cpus),
49 .num_memory_regions = ARRAY_SIZE(config.mem_regions),
50 .num_irqchips = ARRAY_SIZE(config.irqchips),
51 .pio_bitmap_size = ARRAY_SIZE(config.pio_bitmap),
52 .num_pci_devices = ARRAY_SIZE(config.pci_devices),
53 .num_pci_caps = ARRAY_SIZE(config.pci_caps),
66 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
67 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA,
70 .phys_start = 0x3ffdf000,
71 .virt_start = 0x3ffdf000,
73 .flags = JAILHOUSE_MEM_READ,
76 .phys_start = 0xc0000000,
77 .virt_start = 0xc0000000,
79 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
81 /* not safe until we catch MSIs via interrupt remapping */
83 .phys_start = 0xfed00000,
84 .virt_start = 0xfed00000,
86 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
92 .address = 0xfec00000,
93 .pin_bitmap = 0xffffff,
98 [ 0/8 ... 0x3f/8] = -1,
99 [ 0x40/8 ... 0x47/8] = 0xf0, /* PIT */
100 [ 0x48/8 ... 0x5f/8] = -1,
101 [ 0x60/8 ... 0x67/8] = 0xec, /* HACK: 8042, PC speaker - and more */
102 [ 0x68/8 ... 0x6f/8] = -1,
103 [ 0x70/8 ... 0x77/8] = 0xfc, /* rtc */
104 [ 0x78/8 ... 0x7f/8] = -1,
105 [ 0x80/8 ... 0x87/8] = 0xfe, /* port 80 (delays) */
106 [ 0x88/8 ... 0x16f/8] = -1,
107 [ 0x170/8 ... 0x177/8] = 0, /* ide */
108 [ 0x178/8 ... 0x1ef/8] = -1,
109 [ 0x1f0/8 ... 0x1f7/8] = 0, /* ide */
110 [ 0x1f8/8 ... 0x2f7/8] = -1,
111 [ 0x2f8/8 ... 0x2ff/8] = 0, /* serial2 */
112 [ 0x300/8 ... 0x36f/8] = -1,
113 [ 0x370/8 ... 0x377/8] = 0xbf, /* ide */
114 [ 0x378/8 ... 0x3af/8] = -1,
115 [ 0x3b0/8 ... 0x3df/8] = 0, /* VGA */
116 [ 0x3e0/8 ... 0x3ef/8] = -1,
117 [ 0x3f0/8 ... 0x3f7/8] = 0xbf, /* ide */
118 [ 0x3f8/8 ... 0x5657/8] = -1,
119 [0x5658/8 ... 0x565f/8] = 0xf0, /* vmport */
120 [0x5660/8 ... 0xbfff/8] = -1,
121 [0xc000/8 ... 0xc0ff/8] = 0, /* PCI devices */
122 [0xc100/8 ... 0xffff/8] = -1,
126 { /* 440fx: ISA bridge, q35: VGA */
127 .type = JAILHOUSE_PCI_TYPE_DEVICE,
132 .type = JAILHOUSE_PCI_TYPE_DEVICE,
137 .type = JAILHOUSE_PCI_TYPE_DEVICE,
141 { /* 440fx: VGA, q35: e1000 */
142 .type = JAILHOUSE_PCI_TYPE_DEVICE,
146 { /* 44fx: e1000, q35: virtio-9p-pci */
147 .type = JAILHOUSE_PCI_TYPE_DEVICE,
150 .caps_start = 0, /* for q35 */
153 { /* 440fx: virtio-9p-pci */
154 .type = JAILHOUSE_PCI_TYPE_DEVICE,
160 { /* q35: ISA bridge */
161 .type = JAILHOUSE_PCI_TYPE_DEVICE,
166 .type = JAILHOUSE_PCI_TYPE_DEVICE,
173 .type = JAILHOUSE_PCI_TYPE_DEVICE,
180 { /* virtio-9p-pci */
184 .flags = JAILHOUSE_PCICAPS_WRITE,
196 .flags = JAILHOUSE_PCICAPS_WRITE,