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 struct jailhouse_memory mem_regions[20];
22 struct jailhouse_cache cache_regions[1];
23 struct jailhouse_irqchip irqchips[1];
24 struct jailhouse_pio pio_regions[1];
25 struct jailhouse_pci_device pci_devices[4];
26 struct jailhouse_pci_capability pci_caps[6];
27 } __attribute__((packed)) config = {
29 .signature = JAILHOUSE_CELL_DESC_SIGNATURE,
30 .revision = JAILHOUSE_CONFIG_REVISION,
31 .name = "linux-x86-demo",
32 .flags = JAILHOUSE_CELL_PASSIVE_COMMREG |
33 JAILHOUSE_CELL_VIRTUAL_CONSOLE_PERMITTED,
35 .cpu_set_size = sizeof(config.cpus),
36 .num_memory_regions = ARRAY_SIZE(config.mem_regions),
37 .num_cache_regions = ARRAY_SIZE(config.cache_regions),
38 .num_irqchips = ARRAY_SIZE(config.irqchips),
39 .num_pio_regions = ARRAY_SIZE(config.pio_regions),
40 .num_pci_devices = ARRAY_SIZE(config.pci_devices),
41 .num_pci_caps = ARRAY_SIZE(config.pci_caps),
49 /* IVSHMEM shared memory region (virtio-blk front) */
51 .phys_start = 0x27000000, /* to 0x27001000 */
52 .virt_start = 0x27000000,
54 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_ROOTSHARED,
57 .phys_start = 0x27001000,/* to 0x270e0000 */
58 .virt_start = 0x27001000,
60 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
61 JAILHOUSE_MEM_ROOTSHARED,
65 /* IVSHMEM shared memory region (virtio-con front) */
67 .phys_start = 0x270e0000,/* to 0x270e1000 */
68 .virt_start = 0x270e0000,
70 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_ROOTSHARED,
73 .phys_start = 0x270e1000,/*to 0x270f0000 */
74 .virt_start = 0x270e1000,
76 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
77 JAILHOUSE_MEM_ROOTSHARED,
81 /* IVSHMEM shared memory regions (demo) */
83 .phys_start = 0x270f0000,/*to 0x270f1000 */
84 .virt_start = 0x270f0000,
86 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_ROOTSHARED,
89 .phys_start = 0x270f1000,/*to 0x270fa000 */
90 .virt_start = 0x270f1000,
92 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
93 JAILHOUSE_MEM_ROOTSHARED,
96 .phys_start = 0x270fa000,/* to 0x270fc000 */
97 .virt_start = 0x270fa000,
99 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_ROOTSHARED,
102 .phys_start = 0x270fc000,/* to 0x270fe000*/
103 .virt_start = 0x270fc000,
105 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_ROOTSHARED,
108 .phys_start = 0x270fe000,/* to 0x27100000 */
109 .virt_start = 0x270fe000,
111 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
112 JAILHOUSE_MEM_ROOTSHARED,
114 /* IVSHMEM shared memory regions (networking) */
115 JAILHOUSE_SHMEM_NET_REGIONS(0x27100000, 1),
117 .phys_start = 0x22600000,/* to 0x22700000*/
120 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
121 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA |
122 JAILHOUSE_MEM_LOADABLE,
124 /* communication region */ {
126 .virt_start = 0x00100000,
128 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
129 JAILHOUSE_MEM_COMM_REGION,
132 .phys_start = 0x22700000,/*to 0x26e00000 */
133 .virt_start = 0x00200000,
135 .flags = JAILHOUSE_MEM_READ | JAILHOUSE_MEM_WRITE |
136 JAILHOUSE_MEM_EXECUTE | JAILHOUSE_MEM_DMA |
137 JAILHOUSE_MEM_LOADABLE,
145 .type = JAILHOUSE_CACHE_L3,
151 .address = 0xfec00000,
160 PIO_RANGE(0x2f8, 8), /* serial 2 */
161 // PIO_RANGE(0x3f8, 8), /* serial 1 */
162 PIO_RANGE(0xe010, 8), /* OXPCIe952 serial1 */
167 .type = JAILHOUSE_PCI_TYPE_IVSHMEM,
170 .bar_mask = JAILHOUSE_IVSHMEM_BAR_MASK_MSIX,
171 .num_msix_vectors = 2,
172 .shmem_regions_start = 0,
175 .shmem_protocol = JAILHOUSE_SHMEM_PROTO_VIRTIO_FRONT +
179 .type = JAILHOUSE_PCI_TYPE_IVSHMEM,
182 .bar_mask = JAILHOUSE_IVSHMEM_BAR_MASK_MSIX,
183 .num_msix_vectors = 3,
184 .shmem_regions_start = 4,
187 .shmem_protocol = JAILHOUSE_SHMEM_PROTO_VIRTIO_FRONT +
191 .type = JAILHOUSE_PCI_TYPE_IVSHMEM,
194 .bar_mask = JAILHOUSE_IVSHMEM_BAR_MASK_MSIX,
195 .num_msix_vectors = 16,
196 .shmem_regions_start = 8,
199 .shmem_protocol = JAILHOUSE_SHMEM_PROTO_UNDEFINED,
202 .type = JAILHOUSE_PCI_TYPE_IVSHMEM,
205 .bar_mask = JAILHOUSE_IVSHMEM_BAR_MASK_MSIX,
206 .num_msix_vectors = 2,
207 .shmem_regions_start = 13,
210 .shmem_protocol = JAILHOUSE_SHMEM_PROTO_VETH,
216 .id = PCI_CAP_ID_MSI,
219 .flags = JAILHOUSE_PCICAPS_WRITE,
222 .id = PCI_CAP_ID_EXP,
225 .flags = JAILHOUSE_PCICAPS_WRITE,
228 .id = PCI_CAP_ID_MSIX,
231 .flags = JAILHOUSE_PCICAPS_WRITE,
234 .id = PCI_EXT_CAP_ID_ERR | JAILHOUSE_PCI_EXT_CAP,
240 .id = PCI_EXT_CAP_ID_DSN | JAILHOUSE_PCI_EXT_CAP,