/* * Copyright (C) 2018 Intel Corporation. All rights reserved. * * SPDX-License-Identifier: BSD-3-Clause */ #include #define NUM_USER_VMS 2U /**********************/ /* VIRTUAL MACHINE 0 */ /*********************/ /* Number of CPUs in this VM*/ #define VM1_NUM_CPUS 2U /* Logical CPU IDs assigned to this VM */ uint16_t VM1_CPUS[VM1_NUM_CPUS] = {0U, 2U}; /*********************/ /* VIRTUAL MACHINE 1 */ /*********************/ /* Number of CPUs in this VM*/ #define VM2_NUM_CPUS 2U /* Logical CPU IDs assigned with this VM */ uint16_t VM2_CPUS[VM2_NUM_CPUS] = {3U, 1U}; static struct vpci_vdev_array vpci_vdev_array1 = { .num_pci_vdev = 2, .vpci_vdev_list = { {/*vdev 0: hostbridge */ .vbdf = PCI_BDF(0x00U, 0x00U, 0x00U), .ops = &pci_ops_vdev_hostbridge, .bar = {}, /* don't care for hostbridge */ .pdev = {} /* don't care for hostbridge */ }, {/*vdev 1*/ .vbdf = PCI_BDF(0x00U, 0x01U, 0x00U), .ops = &pci_ops_vdev_pt, .bar = { [0] = { .base = 0UL, .size = ALIGN_UP_4K(0x100UL), .type = PCIM_BAR_MEM_32 }, [5] = { .base = 0UL, .size = ALIGN_UP_4K(0x2000UL), .type = PCIM_BAR_MEM_32 }, }, .pdev = { .bdf = PCI_BDF(0x00U, 0x01U, 0x00U), .bar = { [0] = { .base = 0xa9000000UL, .size = 0x100UL, .type = PCIM_BAR_MEM_32 }, [5] = { .base = 0x1a0000000UL, .size = 0x2000UL, .type = PCIM_BAR_MEM_64 }, } } }, } }; static struct vpci_vdev_array vpci_vdev_array2 = { .num_pci_vdev = 2, .vpci_vdev_list = { {/*vdev 0: hostbridge*/ .vbdf = PCI_BDF(0x00U, 0x00U, 0x00U), .ops = &pci_ops_vdev_hostbridge, .bar = {}, /* don't care for hostbridge */ .pdev = {} /* don't care for hostbridge */ }, {/*vdev 1*/ .vbdf = PCI_BDF(0x00U, 0x01U, 0x00U), .ops = &pci_ops_vdev_pt, .bar = { [0] = { .base = 0UL, .size = ALIGN_UP_4K(0x100UL), .type = PCIM_BAR_MEM_32 }, [5] = { .base = 0UL, .size = ALIGN_UP_4K(0x2000UL), .type = PCIM_BAR_MEM_32 }, }, .pdev = { .bdf = PCI_BDF(0x00U, 0x02U, 0x00U), .bar = { [0] = { .base = 0xa8000000UL, .size = 0x100UL, .type = PCIM_BAR_MEM_32 }, [5] = { .base = 0x1b0000000UL, .size = 0x2000UL, .type = PCIM_BAR_MEM_64 }, } } }, } }; /*******************************/ /* User Defined VM definitions */ /*******************************/ const struct vm_description_array vm_desc_partition = { /* Number of user virtual machines */ .num_vm_desc = NUM_USER_VMS, /* Virtual Machine descriptions */ .vm_desc_array = { { /* Internal variable, MUSTBE init to -1 */ .vm_hw_num_cores = VM1_NUM_CPUS, .vm_pcpu_ids = &VM1_CPUS[0], .vm_id = 1U, .start_hpa = 0x100000000UL, .mem_size = 0x20000000UL, /* uses contiguous memory from host */ .vm_vuart = true, .bootargs = "root=/dev/sda rw rootwait noxsave maxcpus=2 nohpet console=hvc0 \ console=ttyS0 no_timer_check ignore_loglevel log_buf_len=16M \ consoleblank=0 tsc=reliable xapic_phys", .vpci_vdev_array = &vpci_vdev_array1, .mptable = &mptable_vm1, }, { /* Internal variable, MUSTBE init to -1 */ .vm_hw_num_cores = VM2_NUM_CPUS, .vm_pcpu_ids = &VM2_CPUS[0], .vm_id = 2U, .start_hpa = 0x120000000UL, .mem_size = 0x20000000UL, /* uses contiguous memory from host */ .vm_vuart = true, .bootargs = "root=/dev/sda rw rootwait noxsave maxcpus=2 nohpet console=hvc0 \ console=ttyS0 no_timer_check ignore_loglevel log_buf_len=16M \ consoleblank=0 tsc=reliable xapic_phys", .vpci_vdev_array = &vpci_vdev_array2, .mptable = &mptable_vm2, }, } }; const struct pcpu_vm_desc_mapping pcpu_vm_desc_map[] = { { .vm_desc_ptr = &vm_desc_partition.vm_desc_array[0], .is_bsp = true, }, { .vm_desc_ptr = &vm_desc_partition.vm_desc_array[1], .is_bsp = false, }, { .vm_desc_ptr = &vm_desc_partition.vm_desc_array[0], .is_bsp = false, }, { .vm_desc_ptr = &vm_desc_partition.vm_desc_array[1], .is_bsp = true, }, }; const struct e820_entry e820_default_entries[NUM_E820_ENTRIES] = { { /* 0 to mptable */ .baseaddr = 0x0U, .length = 0xEFFFFU, .type = E820_TYPE_RAM }, { /* mptable 65536U */ .baseaddr = 0xF0000U, .length = 0x10000U, .type = E820_TYPE_RESERVED }, { /* mptable to lowmem */ .baseaddr = 0x100000U, .length = 0x1FF00000U, .type = E820_TYPE_RAM }, { /* lowmem to PCI hole */ .baseaddr = 0x20000000U, .length = 0xa0000000U, .type = E820_TYPE_RESERVED }, { /* PCI hole to 4G */ .baseaddr = 0xe0000000U, .length = 0x20000000U, .type = E820_TYPE_RESERVED }, };