2 * Jailhouse, a Linux-based partitioning hypervisor
4 * Test configuration for Celsius W420, 4 GB RAM, 64 MB hypervisor
6 * Copyright (c) Siemens AG, 2014
9 * Ivan Kolchin <ivan.kolchin@siemens.com>
11 * NOTE: This config expects the hypervisor to be at 0x1bf00000
13 * This work is licensed under the terms of the GNU GPL, version 2. See
14 * the COPYING file in the top-level directory.
17 #include <linux/types.h>
18 #include <jailhouse/cell-config.h>
20 #define ARRAY_SIZE(a) sizeof(a) / sizeof(a[0])
23 struct jailhouse_system header;
25 struct jailhouse_memory mem_regions[13];
26 struct jailhouse_irqchip irqchips[1];
27 __u8 pio_bitmap[0x2000];
28 struct jailhouse_pci_device pci_devices[13];
29 } __attribute__((packed)) config = {
31 .hypervisor_memory = {
32 .phys_start = 0x1c000000,
36 .phys_start = 0xd8a1a000,
40 .name = "Celsius-W420",
42 .cpu_set_size = sizeof(config.cpus),
43 .num_memory_regions = ARRAY_SIZE(config.mem_regions),
44 .num_irqchips = ARRAY_SIZE(config.irqchips),
45 .pio_bitmap_size = ARRAY_SIZE(config.pio_bitmap),
46 .num_pci_devices = ARRAY_SIZE(config.pci_devices),
59 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
60 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA,
63 .phys_start = 0x1ff00000,
64 .virt_start = 0x1ff00000,
66 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
67 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA,
70 .phys_start = 0x20200000,
71 .virt_start = 0x20200000,
73 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
74 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA,
77 .phys_start = 0x40005000,
78 .virt_start = 0x40005000,
80 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
81 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA,
84 .phys_start = 0xd8a2a000,
85 .virt_start = 0xd8a2a000,
87 .flags = JAILHOUSE_MEM_READ,
90 .phys_start = 0xda382000,
91 .virt_start = 0xda382000,
93 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
94 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA,
97 .phys_start = 0xda383000,
98 .virt_start = 0xda383000,
100 .flags = JAILHOUSE_MEM_READ,
103 .phys_start = 0xda3c6000,
104 .virt_start = 0xda3c6000,
106 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
107 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA,
110 .phys_start = 0xdafef000,
111 .virt_start = 0xdafef000,
113 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
114 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA,
117 .phys_start = 0xdfa00000,
118 .virt_start = 0xdfa00000,
120 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
122 /* not safe until we catch MSIs via interrupt remapping */
124 .phys_start = 0xfed00000,
125 .virt_start = 0xfed00000,
127 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
130 .phys_start = 0x100000000,
131 .virt_start = 0x100000000,
133 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
134 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA,
140 .address = 0xfec00000,
141 .pin_bitmap = 0xffffff,
146 [ 0/8 ... 0x1f/8] = -1,
147 [ 0x20/8 ... 0x27/8] = 0xfc, /* HACK: PIC */
148 [ 0x28/8 ... 0x3f/8] = -1,
149 [ 0x40/8 ... 0x47/8] = 0xf0, /* PIT */
150 [ 0x48/8 ... 0x5f/8] = -1,
151 [ 0x60/8 ... 0x67/8] = 0x0, /* HACK: 8042, and more? */
152 [ 0x68/8 ... 0x6f/8] = -1,
153 [ 0x70/8 ... 0x77/8] = 0xfc, /* rtc */
154 [ 0x78/8 ... 0x7f/8] = -1,
155 [ 0x80/8 ... 0x8f/8] = 0, /* dma */
156 [ 0x90/8 ... 0x16f/8] = -1,
157 [ 0x170/8 ... 0x177/8] = 0, /* ide */
158 [ 0x178/8 ... 0x1ef/8] = -1,
159 [ 0x1f0/8 ... 0x1f7/8] = 0, /* ide */
160 [ 0x1f8/8 ... 0x2f7/8] = -1,
161 [ 0x2f8/8 ... 0x2ff/8] = 0, /* serial2 */
162 [ 0x300/8 ... 0x36f/8] = -1,
163 [ 0x370/8 ... 0x377/8] = 0xbf, /* ide */
164 [ 0x378/8 ... 0x3af/8] = -1,
165 [ 0x3b0/8 ... 0x3df/8] = 0, /* VGA */
166 [ 0x3e0/8 ... 0x3f7/8] = -1,
167 [ 0x3f8/8 ... 0x3ff/8] = 0, /* serial 1 */
168 [ 0x400/8 ... 0x47f/8] = 0, /* ACPI...? */
169 [ 0x480/8 ... 0xcff/8] = -1,
170 [ 0xd00/8 ... 0xffff/8] = 0, /* HACK: full PCI */
175 .type = JAILHOUSE_PCI_TYPE_DEVICE,
178 .devfn = (0x00<<3)|0x0,
181 .type = JAILHOUSE_PCI_TYPE_DEVICE,
184 .devfn = (0x02<<3)|0x0,
187 .type = JAILHOUSE_PCI_TYPE_DEVICE,
190 .devfn = (0x14<<3)|0x0,
193 .type = JAILHOUSE_PCI_TYPE_DEVICE,
196 .devfn = (0x16<<3)|0x0,
199 .type = JAILHOUSE_PCI_TYPE_DEVICE,
202 .devfn = (0x19<<3)|0x0,
205 .type = JAILHOUSE_PCI_TYPE_DEVICE,
208 .devfn = (0x1a<<3)|0x0,
211 .type = JAILHOUSE_PCI_TYPE_DEVICE,
214 .devfn = (0x1b<<3)|0x0,
217 .type = JAILHOUSE_PCI_TYPE_DEVICE,
220 .devfn = (0x1d<<3)|0x0,
223 .type = JAILHOUSE_PCI_TYPE_BRIDGE,
226 .devfn = (0x1e<<3)|0x0,
229 .type = JAILHOUSE_PCI_TYPE_DEVICE,
232 .devfn = (0x1f<<3)|0x0,
235 .type = JAILHOUSE_PCI_TYPE_DEVICE,
238 .devfn = (0x1f<<3)|0x2,
241 .type = JAILHOUSE_PCI_TYPE_DEVICE,
244 .devfn = (0x1f<<3)|0x3,
247 .type = JAILHOUSE_PCI_TYPE_DEVICE,
250 .devfn = (0x1f<<3)|0x6,