2 * Jailhouse, a Linux-based partitioning hypervisor
4 * Copyright (c) Siemens AG, 2014-2017
6 * This work is licensed under the terms of the GNU GPL, version 2. See
7 * the COPYING file in the top-level directory.
9 * Alternatively, you can use or redistribute this file under the following
12 * Redistribution and use in source and binary forms, with or without
13 * modification, are permitted provided that the following conditions
16 * 1. Redistributions of source code must retain the above copyright
17 * notice, this list of conditions and the following disclaimer.
19 * 2. Redistributions in binary form must reproduce the above copyright
20 * notice, this list of conditions and the following disclaimer in the
21 * documentation and/or other materials provided with the distribution.
23 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
24 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
27 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
28 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
29 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
30 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
31 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
32 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
33 * THE POSSIBILITY OF SUCH DAMAGE.
35 * Configuration for QEMU Standard PC (Q35 + ICH9, 2009)
36 * created with '/usr/libexec/jailhouse/jailhouse config create -c ttyS1 qemu-agl.c'
38 * NOTE: This config expects the following to be appended to your kernel cmdline
39 * "memmap=0x5200000$0x22000000"
42 #include <jailhouse/types.h>
43 #include <jailhouse/cell-config.h>
46 struct jailhouse_system header;
48 struct jailhouse_memory mem_regions[17];
49 struct jailhouse_irqchip irqchips[1];
50 struct jailhouse_pio pio_regions[14];
51 struct jailhouse_pci_device pci_devices[13];
52 struct jailhouse_pci_capability pci_caps[14];
53 } __attribute__((packed)) config = {
55 .signature = JAILHOUSE_SYSTEM_SIGNATURE,
56 .revision = JAILHOUSE_CONFIG_REVISION,
57 .flags = JAILHOUSE_SYS_VIRTUAL_DEBUG_CONSOLE,
58 .hypervisor_memory = {
59 .phys_start = 0x22000000,
64 .type = JAILHOUSE_CON_TYPE_8250,
65 .flags = JAILHOUSE_CON_ACCESS_PIO |
66 JAILHOUSE_CON_REGDIST_1,
69 .pci_mmconfig_base = 0xb0000000,
70 .pci_mmconfig_end_bus = 0xff,
73 .type = JAILHOUSE_IOMMU_INTEL,
79 .pm_timer_address = 0x608,
80 .vtd_interrupt_limit = 256,
85 .cpu_set_size = sizeof(config.cpus),
86 .num_memory_regions = ARRAY_SIZE(config.mem_regions),
87 .num_irqchips = ARRAY_SIZE(config.irqchips),
88 .num_pio_regions = ARRAY_SIZE(config.pio_regions),
89 .num_pci_devices = ARRAY_SIZE(config.pci_devices),
90 .num_pci_caps = ARRAY_SIZE(config.pci_caps),
99 /* MemRegion: 00000000-0009fbff : System RAM */
104 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
105 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA,
107 /* MemRegion: 00100000-201fffff : System RAM */
109 .phys_start = 0x100000,
110 .virt_start = 0x100000,
112 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
113 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA,
115 /* MemRegion: 20200000-21ffffff : Kernel */
117 .phys_start = 0x20200000,
118 .virt_start = 0x20200000,
120 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
121 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA,
123 /* MemRegion: 27200000-31ffffff : System RAM */
125 .phys_start = 0x27200000,
126 .virt_start = 0x27200000,
128 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
129 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA,
131 /* MemRegion: 32000000-33ffffff : RAM buffer */
133 .phys_start = 0x32000000,
134 .virt_start = 0x32000000,
136 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
137 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA,
139 /* MemRegion: fe000000-fe7fffff : 0000:00:01.0 */
141 .phys_start = 0xfe000000,
142 .virt_start = 0xfe000000,
144 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
146 /* MemRegion: fe800000-fe803fff : virtio-pci-modern */
148 .phys_start = 0xfe800000,
149 .virt_start = 0xfe800000,
151 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
153 /* MemRegion: fe804000-fe807fff : virtio-pci-modern */
155 .phys_start = 0xfe804000,
156 .virt_start = 0xfe804000,
158 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
160 /* MemRegion: fe808000-fe80bfff : virtio-pci-modern */
162 .phys_start = 0xfe808000,
163 .virt_start = 0xfe808000,
165 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
167 /* MemRegion: fe80c000-fe80ffff : virtio-pci-modern */
169 .phys_start = 0xfe80c000,
170 .virt_start = 0xfe80c000,
172 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
174 /* MemRegion: feb80000-febbffff : 0000:00:02.0 */
176 .phys_start = 0xfeb80000,
177 .virt_start = 0xfeb80000,
179 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
181 /* MemRegion: febd0000-febd3fff : ICH HD audio */
183 .phys_start = 0xfebd0000,
184 .virt_start = 0xfebd0000,
186 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
188 /* MemRegion: febd7000-febd7fff : ehci_hcd */
190 .phys_start = 0xfebd7000,
191 .virt_start = 0xfebd7000,
193 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
195 /* MemRegion: febd8000-febd8fff : ahci */
197 .phys_start = 0xfebd8000,
198 .virt_start = 0xfebd8000,
200 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
202 /* MemRegion: fed00000-fed003ff : PNP0103:00 */
204 .phys_start = 0xfed00000,
205 .virt_start = 0xfed00000,
207 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
209 /* MemRegion: 000c0000-000dffff : ROMs */
211 .phys_start = 0xc0000,
212 .virt_start = 0xc0000,
214 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
216 /* MemRegion: 22600000-271fffff : JAILHOUSE Inmate Memory */
218 .phys_start = 0x22600000,
219 .virt_start = 0x22600000,
221 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
226 /* IOAPIC 0, GSI base 0 */
228 .address = 0xfec00000,
231 0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff
237 /* Port I/O: 0000-001f : dma1 */
238 /* PIO_RANGE(0x0, 0x20), */
239 /* Port I/O: 0020-0021 : pic1 */
240 /* PIO_RANGE(0x20, 0x2), */
241 /* Port I/O: 0040-0043 : timer0 */
242 PIO_RANGE(0x40, 0x4),
243 /* Port I/O: 0050-0053 : timer1 */
244 /* PIO_RANGE(0x50, 0x4), */
245 /* Port I/O: 0060-0060 : keyboard */
246 PIO_RANGE(0x60, 0x1),
247 /* Port I/O: 0064-0064 : keyboard */
248 PIO_RANGE(0x64, 0x1),
249 /* Port I/O: 0070-0077 : rtc0 */
250 PIO_RANGE(0x70, 0x8),
251 /* Port I/O: 0080-008f : dma page reg */
252 /* PIO_RANGE(0x80, 0x10), */
253 /* Port I/O: 00a0-00a1 : pic2 */
254 /* PIO_RANGE(0xa0, 0x2), */
255 /* Port I/O: 00c0-00df : dma2 */
256 /* PIO_RANGE(0xc0, 0x20), */
257 /* Port I/O: 00f0-00ff : fpu */
258 /* PIO_RANGE(0xf0, 0x10), */
259 /* Port I/O: 02f8-02ff : serial */
260 PIO_RANGE(0x2f8, 0x8),
261 /* Port I/O: 0378-037a : parport0 */
262 /* PIO_RANGE(0x378, 0x3), */
263 /* Port I/O: 03c0-03df : vga+ */
264 PIO_RANGE(0x3c0, 0x20),
265 /* Port I/O: 03f8-03ff : serial */
266 PIO_RANGE(0x3f8, 0x8),
267 /* Port I/O: 0510-051b : QEMU0002:00 */
268 /* PIO_RANGE(0x510, 0xc), */
269 /* Port I/O: 0600-0603 : ACPI PM1a_EVT_BLK */
270 /* PIO_RANGE(0x600, 0x4), */
271 /* Port I/O: 0604-0605 : ACPI PM1a_CNT_BLK */
272 /* PIO_RANGE(0x604, 0x2), */
273 /* Port I/O: 0608-060b : ACPI PM_TMR */
274 /* PIO_RANGE(0x608, 0x4), */
275 /* Port I/O: 0620-062f : ACPI GPE0_BLK */
276 /* PIO_RANGE(0x620, 0x10), */
277 /* Port I/O: 0700-073f : i801_smbus */
278 /* PIO_RANGE(0x700, 0x40), */
279 /* Port I/O: c000-c07f : 0000:00:04.0 */
280 PIO_RANGE(0xc000, 0x80),
281 /* Port I/O: c0c0-c0df : 0000:00:02.0 */
282 PIO_RANGE(0xc0c0, 0x20),
283 /* Port I/O: c0e0-c0ff : 0000:00:03.0 */
284 PIO_RANGE(0xc0e0, 0x20),
285 /* Port I/O: c100-c11f : 0000:00:1d.0 */
286 PIO_RANGE(0xc100, 0x20),
287 /* Port I/O: c120-c13f : 0000:00:1d.1 */
288 PIO_RANGE(0xc120, 0x20),
289 /* Port I/O: c140-c15f : 0000:00:1d.2 */
290 PIO_RANGE(0xc140, 0x20),
291 /* Port I/O: c160-c17f : 0000:00:1f.2 */
292 PIO_RANGE(0xc160, 0x20),
296 /* PCIDevice: 00:00.0 */
298 .type = JAILHOUSE_PCI_TYPE_DEVICE,
303 0x00000000, 0x00000000, 0x00000000,
304 0x00000000, 0x00000000, 0x00000000,
308 .num_msi_vectors = 0,
311 .num_msix_vectors = 0,
312 .msix_region_size = 0x0,
315 /* PCIDevice: 00:01.0 */
317 .type = JAILHOUSE_PCI_TYPE_DEVICE,
322 0xff800000, 0x00000000, 0xffffc000,
323 0xffffffff, 0xfffff000, 0x00000000,
327 .num_msi_vectors = 0,
330 .num_msix_vectors = 3,
331 .msix_region_size = 0x1000,
332 .msix_address = 0xfebd4000,
334 /* PCIDevice: 00:02.0 */
336 .type = JAILHOUSE_PCI_TYPE_DEVICE,
341 0xffffffe0, 0xfffff000, 0x00000000,
342 0x00000000, 0xffffc000, 0xffffffff,
346 .num_msi_vectors = 0,
349 .num_msix_vectors = 3,
350 .msix_region_size = 0x1000,
351 .msix_address = 0xfebd5000,
353 /* PCIDevice: 00:03.0 */
355 .type = JAILHOUSE_PCI_TYPE_DEVICE,
360 0xffffffe0, 0x00000000, 0x00000000,
361 0x00000000, 0xffffc000, 0xffffffff,
365 .num_msi_vectors = 0,
368 .num_msix_vectors = 0,
369 .msix_region_size = 0x0,
372 /* PCIDevice: 00:04.0 */
374 .type = JAILHOUSE_PCI_TYPE_DEVICE,
379 0xffffff80, 0xfffff000, 0x00000000,
380 0x00000000, 0xffffc000, 0xffffffff,
384 .num_msi_vectors = 0,
387 .num_msix_vectors = 2,
388 .msix_region_size = 0x1000,
389 .msix_address = 0xfebd6000,
391 /* PCIDevice: 00:1b.0 */
393 .type = JAILHOUSE_PCI_TYPE_DEVICE,
398 0xffffc000, 0x00000000, 0x00000000,
399 0x00000000, 0x00000000, 0x00000000,
403 .num_msi_vectors = 1,
406 .num_msix_vectors = 0,
407 .msix_region_size = 0x0,
410 /* PCIDevice: 00:1d.0 */
412 .type = JAILHOUSE_PCI_TYPE_DEVICE,
417 0x00000000, 0x00000000, 0x00000000,
418 0x00000000, 0xffffffe0, 0x00000000,
422 .num_msi_vectors = 0,
425 .num_msix_vectors = 0,
426 .msix_region_size = 0x0,
429 /* PCIDevice: 00:1d.1 */
431 .type = JAILHOUSE_PCI_TYPE_DEVICE,
436 0x00000000, 0x00000000, 0x00000000,
437 0x00000000, 0xffffffe0, 0x00000000,
441 .num_msi_vectors = 0,
444 .num_msix_vectors = 0,
445 .msix_region_size = 0x0,
448 /* PCIDevice: 00:1d.2 */
450 .type = JAILHOUSE_PCI_TYPE_DEVICE,
455 0x00000000, 0x00000000, 0x00000000,
456 0x00000000, 0xffffffe0, 0x00000000,
460 .num_msi_vectors = 0,
463 .num_msix_vectors = 0,
464 .msix_region_size = 0x0,
467 /* PCIDevice: 00:1d.7 */
469 .type = JAILHOUSE_PCI_TYPE_DEVICE,
474 0xfffff000, 0x00000000, 0x00000000,
475 0x00000000, 0x00000000, 0x00000000,
479 .num_msi_vectors = 0,
482 .num_msix_vectors = 0,
483 .msix_region_size = 0x0,
486 /* PCIDevice: 00:1f.0 */
488 .type = JAILHOUSE_PCI_TYPE_DEVICE,
493 0x00000000, 0x00000000, 0x00000000,
494 0x00000000, 0x00000000, 0x00000000,
498 .num_msi_vectors = 0,
501 .num_msix_vectors = 0,
502 .msix_region_size = 0x0,
505 /* PCIDevice: 00:1f.2 */
507 .type = JAILHOUSE_PCI_TYPE_DEVICE,
512 0x00000000, 0x00000000, 0x00000000,
513 0x00000000, 0xffffffe0, 0xfffff000,
517 .num_msi_vectors = 1,
520 .num_msix_vectors = 0,
521 .msix_region_size = 0x0,
524 /* PCIDevice: 00:1f.3 */
526 .type = JAILHOUSE_PCI_TYPE_DEVICE,
531 0x00000000, 0x00000000, 0x00000000,
532 0x00000000, 0xffffffc0, 0x00000000,
536 .num_msi_vectors = 0,
539 .num_msix_vectors = 0,
540 .msix_region_size = 0x0,
546 /* PCIDevice: 00:01.0 */
547 /* PCIDevice: 00:02.0 */
548 /* PCIDevice: 00:04.0 */
550 .id = PCI_CAP_ID_MSIX,
553 .flags = JAILHOUSE_PCICAPS_WRITE,
556 .id = PCI_CAP_ID_VNDR,
562 .id = PCI_CAP_ID_VNDR,
568 .id = PCI_CAP_ID_VNDR,
574 .id = PCI_CAP_ID_VNDR,
580 .id = PCI_CAP_ID_VNDR,
585 /* PCIDevice: 00:03.0 */
587 .id = PCI_CAP_ID_VNDR,
593 .id = PCI_CAP_ID_VNDR,
599 .id = PCI_CAP_ID_VNDR,
605 .id = PCI_CAP_ID_VNDR,
611 .id = PCI_CAP_ID_VNDR,
616 /* PCIDevice: 00:1b.0 */
618 .id = PCI_CAP_ID_MSI,
621 .flags = JAILHOUSE_PCICAPS_WRITE,
623 /* PCIDevice: 00:1f.2 */
625 .id = PCI_CAP_ID_MSI,
628 .flags = JAILHOUSE_PCICAPS_WRITE,
631 .id = PCI_CAP_ID_SATA,