2 * Jailhouse, a Linux-based partitioning hypervisor
4 * Test configuration for QEMU Q35 VM, 1 GB RAM, 64 MB hypervisor (-192K ACPI)
7 * For Intel-based setup:
8 * qemu-system-x86_64 -machine q35 -m 1G -enable-kvm -smp 4 \
9 * -drive file=/path/to/image,id=disk,if=none -device ide-hd,drive=disk \
10 * -virtfs local,path=/local/path,security_model=passthrough,mount_tag=host \
11 * -cpu kvm64,-kvm_pv_eoi,-kvm_steal_time,-kvm_asyncpf,-kvmclock,+vmx,+x2apic
13 * For AMD-based setups:
14 * qemu-system-x86_64 /path/to/image -m 1G -enable-kvm -smp 4 \
15 * -virtfs local,path=/local/path,security_model=passthrough,mount_tag=host \
16 * -cpu host,-kvm_pv_eoi,-kvm_steal_time,-kvm_asyncpf,-kvmclock,+svm,+x2apic
18 * Copyright (c) Siemens AG, 2013
21 * Jan Kiszka <jan.kiszka@siemens.com>
23 * This work is licensed under the terms of the GNU GPL, version 2. See
24 * the COPYING file in the top-level directory.
27 #include <linux/types.h>
28 #include <jailhouse/cell-config.h>
30 #define ARRAY_SIZE(a) sizeof(a) / sizeof(a[0])
33 struct jailhouse_system header;
35 struct jailhouse_memory mem_regions[11];
36 struct jailhouse_irqchip irqchips[1];
37 __u8 pio_bitmap[0x2000];
38 struct jailhouse_pci_device pci_devices[7];
39 struct jailhouse_pci_capability pci_caps[5];
40 } __attribute__((packed)) config = {
42 .hypervisor_memory = {
43 .phys_start = 0x3b000000,
46 .platform_info.x86 = {
47 .mmconfig_base = 0xb0000000,
48 .mmconfig_end_bus = 0xff,
49 .pm_timer_address = 0x608,
54 .interrupt_limit = 256,
58 .cpu_set_size = sizeof(config.cpus),
59 .num_memory_regions = ARRAY_SIZE(config.mem_regions),
60 .num_irqchips = ARRAY_SIZE(config.irqchips),
61 .pio_bitmap_size = ARRAY_SIZE(config.pio_bitmap),
62 .num_pci_devices = ARRAY_SIZE(config.pci_devices),
63 .num_pci_caps = ARRAY_SIZE(config.pci_caps),
76 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
77 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA,
80 .phys_start = 0x3f000000,
81 .virt_start = 0x3f000000,
83 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
84 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA,
87 .phys_start = 0x3ffdf000,
88 .virt_start = 0x3ffdf000,
90 .flags = JAILHOUSE_MEM_READ,
92 /* MemRegion: fc000000-fc3fffff : vesafb */
94 .phys_start = 0xfc000000,
95 .virt_start = 0xfc000000,
97 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
99 /* MemRegion: feb80000-febbffff : 0000:00:02.0 */
101 .phys_start = 0xfeb80000,
102 .virt_start = 0xfeb80000,
104 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
106 /* MemRegion: febc0000-febdffff : e1000 */
108 .phys_start = 0xfebc0000,
109 .virt_start = 0xfebc0000,
111 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
113 /* MemRegion: febe0000-febeffff : 0000:00:01.0 */
115 .phys_start = 0xfebe0000,
116 .virt_start = 0xfebe0000,
118 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
120 /* MemRegion: febf0000-febf3fff : ICH HD audio */
122 .phys_start = 0xfebf0000,
123 .virt_start = 0xfebf0000,
125 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
127 /* MemRegion: febf4000-febf4fff : 0000:00:01.0 */
129 .phys_start = 0xfebf4000,
130 .virt_start = 0xfebf4000,
132 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
134 /* MemRegion: febf5000-febf5fff : ahci */
136 .phys_start = 0xfebf5000,
137 .virt_start = 0xfebf5000,
139 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
141 /* MemRegion: fed00000-fed003ff : PNP0103:00 */
143 .phys_start = 0xfed00000,
144 .virt_start = 0xfed00000,
146 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
152 .address = 0xfec00000,
154 .pin_bitmap = 0xffffff,
159 [ 0/8 ... 0x1f/8] = 0, /* floppy DMA controller */
160 [ 0x20/8 ... 0x3f/8] = -1,
161 [ 0x40/8 ... 0x47/8] = 0xf0, /* PIT */
162 [ 0x48/8 ... 0x5f/8] = -1,
163 [ 0x60/8 ... 0x67/8] = 0xec, /* HACK: NMI status/control */
164 [ 0x68/8 ... 0x6f/8] = -1,
165 [ 0x70/8 ... 0x77/8] = 0xfc, /* rtc */
166 [ 0x78/8 ... 0x7f/8] = -1,
167 [ 0x80/8 ... 0x87/8] = 0xfe, /* port 80 (delays) */
168 [ 0x88/8 ... 0x2f7/8] = -1,
169 [ 0x2f8/8 ... 0x2ff/8] = 0, /* serial2 */
170 [ 0x300/8 ... 0x3af/8] = -1,
171 [ 0x3b0/8 ... 0x3df/8] = 0, /* VGA */
172 [ 0x3e0/8 ... 0x3ef/8] = -1,
173 [ 0x3f0/8 ... 0x3f7/8] = 0, /* floppy */
174 [ 0x3f8/8 ... 0x5657/8] = -1,
175 [0x5658/8 ... 0x565f/8] = 0xf0, /* vmport */
176 [0x5660/8 ... 0xbfff/8] = -1,
177 [0xc000/8 ... 0xc0ff/8] = 0, /* PCI devices */
178 [0xc100/8 ... 0xffff/8] = -1,
183 .type = JAILHOUSE_PCI_TYPE_DEVICE,
188 .type = JAILHOUSE_PCI_TYPE_DEVICE,
193 .type = JAILHOUSE_PCI_TYPE_DEVICE,
198 .num_msi_vectors = 1,
202 .type = JAILHOUSE_PCI_TYPE_DEVICE,
207 .type = JAILHOUSE_PCI_TYPE_DEVICE,
212 .num_msi_vectors = 1,
216 .type = JAILHOUSE_PCI_TYPE_DEVICE,
220 { /* virtio-9p-pci */
221 .type = JAILHOUSE_PCI_TYPE_DEVICE,
226 .num_msix_vectors = 2,
227 .msix_region_size = 0x1000,
228 .msix_address = 0xfebf6000,
237 .flags = JAILHOUSE_PCICAPS_WRITE,
239 { /* non-cap registers: HDCTL, TCSEL, DCKCTL, DCKSTS */
242 .flags = JAILHOUSE_PCICAPS_WRITE,
254 .flags = JAILHOUSE_PCICAPS_WRITE,
256 { /* virtio-9p-pci */
260 .flags = JAILHOUSE_PCICAPS_WRITE,