2 * Jailhouse, a Linux-based partitioning hypervisor
4 * Test configuration for Asus H87I-PLUS, 4 GB RAM, 64 MB hypervisor
6 * Copyright (c) Siemens AG, 2013
9 * Jan Kiszka <jan.kiszka@siemens.com>
11 * This work is licensed under the terms of the GNU GPL, version 2. See
12 * the COPYING file in the top-level directory.
15 #include <linux/types.h>
16 #include <jailhouse/cell-config.h>
18 #define ARRAY_SIZE(a) sizeof(a) / sizeof(a[0])
21 struct jailhouse_system header;
23 struct jailhouse_memory mem_regions[9];
24 struct jailhouse_irqchip irqchips[1];
25 __u8 pio_bitmap[0x2000];
26 struct jailhouse_pci_device pci_devices[13];
27 struct jailhouse_pci_capability pci_caps[28];
28 } __attribute__((packed)) config = {
30 .hypervisor_memory = {
31 .phys_start = 0x3b000000,
34 .platform_info.x86 = {
35 .mmconfig_base = 0xf8000000,
36 .mmconfig_end_bus = 0x3f,
37 .pm_timer_address = 0x1808,
43 .interrupt_limit = 256,
47 .cpu_set_size = sizeof(config.cpus),
48 .num_memory_regions = ARRAY_SIZE(config.mem_regions),
49 .num_irqchips = ARRAY_SIZE(config.irqchips),
50 .pio_bitmap_size = ARRAY_SIZE(config.pio_bitmap),
51 .num_pci_devices = ARRAY_SIZE(config.pci_devices),
52 .num_pci_caps = ARRAY_SIZE(config.pci_caps),
65 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
66 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA,
69 .phys_start = 0x3f000000,
70 .virt_start = 0x3f000000,
72 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
73 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA,
76 .phys_start = 0xcca63000,
77 .virt_start = 0xcca63000,
79 .flags = JAILHOUSE_MEM_READ,
82 .phys_start = 0xcdfff000,
83 .virt_start = 0xcdfff000,
85 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
86 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA,
89 .phys_start = 0xcf200000,
90 .virt_start = 0xcf200000,
92 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
93 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA,
96 .phys_start = 0xdf200000,
97 .virt_start = 0xdf200000,
99 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
101 /* not safe until we catch MSIs via interrupt remapping */
103 .phys_start = 0xfed00000,
104 .virt_start = 0xfed00000,
106 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
109 .phys_start = 0x100000000,
110 .virt_start = 0x100000000,
112 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
113 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA,
119 .address = 0xfec00000,
121 .pin_bitmap = 0xffffff,
126 [ 0/8 ... 0x3f/8] = -1,
127 [ 0x40/8 ... 0x47/8] = 0xf0, /* PIT */
128 [ 0x48/8 ... 0x5f/8] = -1,
129 [ 0x60/8 ... 0x67/8] = 0xec, /* HACK: NMI status/control */
130 [ 0x68/8 ... 0x6f/8] = -1,
131 [ 0x70/8 ... 0x77/8] = 0xfc, /* rtc */
132 [ 0x78/8 ... 0x3af/8] = -1,
133 [ 0x3b0/8 ... 0x3df/8] = 0, /* VGA */
134 [ 0x3e0/8 ... 0xcff/8] = -1,
135 [ 0xd00/8 ... 0xffff/8] = 0, /* HACK: full PCI */
139 /* PCIDevice: 00:00.0 */
141 .type = JAILHOUSE_PCI_TYPE_DEVICE,
148 /* PCIDevice: 00:01.0 */
150 .type = JAILHOUSE_PCI_TYPE_BRIDGE,
156 .num_msi_vectors = 1,
158 /* PCIDevice: 00:02.0 */
160 .type = JAILHOUSE_PCI_TYPE_DEVICE,
166 .num_msi_vectors = 1,
168 /* PCIDevice: 00:03.0 */
170 .type = JAILHOUSE_PCI_TYPE_DEVICE,
176 .num_msi_vectors = 1,
178 /* PCIDevice: 00:14.0 */
180 .type = JAILHOUSE_PCI_TYPE_DEVICE,
186 .num_msi_vectors = 8,
189 /* PCIDevice: 00:16.0 */
191 .type = JAILHOUSE_PCI_TYPE_DEVICE,
197 .num_msi_vectors = 1,
200 /* PCIDevice: 00:19.0 */
202 .type = JAILHOUSE_PCI_TYPE_DEVICE,
208 .num_msi_vectors = 1,
211 /* PCIDevice: 00:1a.0 */
213 .type = JAILHOUSE_PCI_TYPE_DEVICE,
220 /* PCIDevice: 00:1b.0 */
222 .type = JAILHOUSE_PCI_TYPE_DEVICE,
228 .num_msi_vectors = 1,
231 /* PCIDevice: 00:1d.0 */
233 .type = JAILHOUSE_PCI_TYPE_DEVICE,
240 /* PCIDevice: 00:1f.0 */
242 .type = JAILHOUSE_PCI_TYPE_DEVICE,
249 /* PCIDevice: 00:1f.2 */
251 .type = JAILHOUSE_PCI_TYPE_DEVICE,
257 .num_msi_vectors = 1,
259 /* PCIDevice: 00:1f.3 */
261 .type = JAILHOUSE_PCI_TYPE_DEVICE,
271 /* PCIDevice: 00:00.0 */
272 /* PCIDevice: 00:1f.0 */
279 /* PCIDevice: 00:01.0 */
290 .flags = JAILHOUSE_PCICAPS_WRITE,
296 .flags = JAILHOUSE_PCICAPS_WRITE,
304 /* PCIDevice: 00:02.0 */
309 .flags = JAILHOUSE_PCICAPS_WRITE,
315 .flags = JAILHOUSE_PCICAPS_WRITE,
323 /* PCIDevice: 00:03.0 */
328 .flags = JAILHOUSE_PCICAPS_WRITE,
334 .flags = JAILHOUSE_PCICAPS_WRITE,
342 /* PCIDevice: 00:14.0 */
347 .flags = JAILHOUSE_PCICAPS_WRITE,
353 .flags = JAILHOUSE_PCICAPS_WRITE,
355 /* PCIDevice: 00:16.0 */
360 .flags = JAILHOUSE_PCICAPS_WRITE,
366 .flags = JAILHOUSE_PCICAPS_WRITE,
368 /* PCIDevice: 00:19.0 */
373 .flags = JAILHOUSE_PCICAPS_WRITE,
379 .flags = JAILHOUSE_PCICAPS_WRITE,
387 /* PCIDevice: 00:1a.0 */
388 /* PCIDevice: 00:1d.0 */
393 .flags = JAILHOUSE_PCICAPS_WRITE,
407 /* PCIDevice: 00:1b.0 */
412 .flags = JAILHOUSE_PCICAPS_WRITE,
418 .flags = JAILHOUSE_PCICAPS_WRITE,
426 { /* non-cap registers: HDCTL, TCSEL, DCKCTL,DCKSTS */
429 .flags = JAILHOUSE_PCICAPS_WRITE,
431 /* PCIDevice: 00:1f.2 */
436 .flags = JAILHOUSE_PCICAPS_WRITE,
442 .flags = JAILHOUSE_PCICAPS_WRITE,