2 * Jailhouse, a Linux-based partitioning hypervisor
4 * Configuration for Linux inmate, 1 CPU, 74 MB RAM, ~1MB shmem, serial ports
6 * Copyright (c) Siemens AG, 2013-2015
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 <jailhouse/types.h>
16 #include <jailhouse/cell-config.h>
19 struct jailhouse_cell_desc cell;
21 #ifdef CONFIG_QEMU_E1000E_ASSIGNMENT
22 struct jailhouse_memory mem_regions[24];
24 struct jailhouse_memory mem_regions[20];
26 struct jailhouse_cache cache_regions[1];
27 struct jailhouse_irqchip irqchips[1];
28 struct jailhouse_pio pio_regions[2];
29 #ifdef CONFIG_QEMU_E1000E_ASSIGNMENT
30 struct jailhouse_pci_device pci_devices[5];
32 struct jailhouse_pci_device pci_devices[4];
34 struct jailhouse_pci_capability pci_caps[6];
35 } __attribute__((packed)) config = {
37 .signature = JAILHOUSE_CELL_DESC_SIGNATURE,
38 .revision = JAILHOUSE_CONFIG_REVISION,
39 .name = "agl-linux-x86-demo",
40 .flags = JAILHOUSE_CELL_PASSIVE_COMMREG |
41 JAILHOUSE_CELL_VIRTUAL_CONSOLE_PERMITTED,
43 .cpu_set_size = sizeof(config.cpus),
44 .num_memory_regions = ARRAY_SIZE(config.mem_regions),
45 .num_cache_regions = ARRAY_SIZE(config.cache_regions),
46 .num_irqchips = ARRAY_SIZE(config.irqchips),
47 .num_pio_regions = ARRAY_SIZE(config.pio_regions),
48 .num_pci_devices = ARRAY_SIZE(config.pci_devices),
49 .num_pci_caps = ARRAY_SIZE(config.pci_caps),
58 /* IVSHMEM shared memory region (virtio-blk front) */
60 .phys_start = 0x22000000,
61 .virt_start = 0x22000000,
63 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_ROOTSHARED,
66 .phys_start = 0x22001000,
67 .virt_start = 0x22001000,
69 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
70 JAILHOUSE_MEM_ROOTSHARED,
74 /* IVSHMEM shared memory region (virtio-con front) */
76 .phys_start = 0x220e0000,
77 .virt_start = 0x220e0000,
79 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_ROOTSHARED,
82 .phys_start = 0x220e1000,
83 .virt_start = 0x220e1000,
85 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
86 JAILHOUSE_MEM_ROOTSHARED,
91 /* IVSHMEM shared memory regions (demo) */
93 .phys_start = 0x220f0000,
94 .virt_start = 0x220f0000,
96 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_ROOTSHARED,
99 .phys_start = 0x220f1000,
100 .virt_start = 0x220f1000,
102 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
103 JAILHOUSE_MEM_ROOTSHARED,
106 .phys_start = 0x220fa000,
107 .virt_start = 0x220fa000,
109 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_ROOTSHARED,
112 .phys_start = 0x220fc000,
113 .virt_start = 0x220fc000,
115 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_ROOTSHARED,
118 .phys_start = 0x220fe000,
119 .virt_start = 0x220fe000,
121 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
122 JAILHOUSE_MEM_ROOTSHARED,
124 /* IVSHMEM shared memory regions (networking) */
125 JAILHOUSE_SHMEM_NET_REGIONS(0x22100000, 1),
127 .phys_start = 0x22600000,
130 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
131 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA |
132 JAILHOUSE_MEM_LOADABLE,
134 /* communication region */ {
135 .virt_start = 0x00100000,
137 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
138 JAILHOUSE_MEM_COMM_REGION,
141 .phys_start = 0x22700000,
142 .virt_start = 0x00200000,
144 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
145 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA |
146 JAILHOUSE_MEM_LOADABLE,
148 #ifdef CONFIG_QEMU_E1000E_ASSIGNMENT
149 /* MemRegion: feb40000-feb7ffff : 0000:00:02.0 */
151 .phys_start = 0xfeb40000,
152 .virt_start = 0xfeb40000,
154 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
156 /* MemRegion: feb80000-feb9ffff : e1000e */
158 .phys_start = 0xfeb80000,
159 .virt_start = 0xfeb80000,
161 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
163 /* MemRegion: feba0000-febbffff : e1000e */
165 .phys_start = 0xfeba0000,
166 .virt_start = 0xfeba0000,
168 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
170 /* MemRegion: febd1000-febd3fff : e1000e */
172 .phys_start = 0xfebd1000,
173 .virt_start = 0xfebd1000,
175 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE,
184 .type = JAILHOUSE_CACHE_L3,
190 .address = 0xfec00000,
199 PIO_RANGE(0x2e8, 8), /* serial 2: ttyS3(0x2e8) */
200 PIO_RANGE(0x3e8, 8), /* serial 1: ttyS2(0x3e8) */
201 // PIO_RANGE(0xe010, 8), /* OXPCIe952 serial1 */
206 .type = JAILHOUSE_PCI_TYPE_IVSHMEM,
209 .bar_mask = JAILHOUSE_IVSHMEM_BAR_MASK_MSIX,
210 .num_msix_vectors = 2,
211 .shmem_regions_start = 0,
214 .shmem_protocol = JAILHOUSE_SHMEM_PROTO_VIRTIO_FRONT +
218 .type = JAILHOUSE_PCI_TYPE_IVSHMEM,
221 .bar_mask = JAILHOUSE_IVSHMEM_BAR_MASK_MSIX,
222 .num_msix_vectors = 3,
223 .shmem_regions_start = 4,
226 .shmem_protocol = JAILHOUSE_SHMEM_PROTO_VIRTIO_FRONT +
230 .type = JAILHOUSE_PCI_TYPE_IVSHMEM,
233 .bar_mask = JAILHOUSE_IVSHMEM_BAR_MASK_MSIX,
234 .num_msix_vectors = 16,
235 .shmem_regions_start = 8,
238 .shmem_protocol = JAILHOUSE_SHMEM_PROTO_UNDEFINED,
241 .type = JAILHOUSE_PCI_TYPE_IVSHMEM,
244 .bar_mask = JAILHOUSE_IVSHMEM_BAR_MASK_MSIX,
245 .num_msix_vectors = 2,
246 .shmem_regions_start = 13,
249 .shmem_protocol = JAILHOUSE_SHMEM_PROTO_VETH,
251 #ifdef CONFIG_QEMU_E1000E_ASSIGNMENT
253 .type = JAILHOUSE_PCI_TYPE_DEVICE,
257 0xfffe0000, 0xfffe0000, 0xffffffe0,
258 0xffffc000, 0x00000000, 0x00000000,
262 .num_msi_vectors = 1,
264 .num_msix_vectors = 5,
265 .msix_region_size = 0x1000,
266 .msix_address = 0xfebd0000,
276 .flags = JAILHOUSE_PCICAPS_WRITE,
279 .id = PCI_CAP_ID_MSI,
282 .flags = JAILHOUSE_PCICAPS_WRITE,
285 .id = PCI_CAP_ID_EXP,
288 .flags = JAILHOUSE_PCICAPS_WRITE,
291 .id = PCI_CAP_ID_MSIX,
294 .flags = JAILHOUSE_PCICAPS_WRITE,
297 .id = PCI_EXT_CAP_ID_ERR | JAILHOUSE_PCI_EXT_CAP,
303 .id = PCI_EXT_CAP_ID_DSN | JAILHOUSE_PCI_EXT_CAP,