[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-devel] [PATCH v5 14/25] xen/arm: introduce create_domUs
Call a new function, "create_domUs", from setup_xen to start DomU VMs. Introduce support for the "xen,domain" compatible node on device tree. Create new DomU VMs based on the information found on device tree under "xen,domain". Call construct_domU for each domain. Introduce a simple global variable named max_init_domid to keep track of the initial allocated domids. It holds the max domid among the initial domains. Move the discard_initial_modules after DomUs have been built. First create domUs, then start dom0 -- no point in trying to start dom0 when the cpu is busy. Signed-off-by: Stefano Stabellini <stefanos@xxxxxxxxxx> Acked-by: Jan Beulich <jbeulich@xxxxxxxx> CC: andrew.cooper3@xxxxxxxxxx CC: jbeulich@xxxxxxxx --- Changes in v5: - use dt_property_read_bool - improve commit message - code style - use dt_find_node_by_path instead of dt_find_node_by_name - use true with is_console Changes in v4: - constify parameters - nr_spis to 0 or GUEST_VPL011_SPI - 32 + 1 depending on vpl011 - remove pointless initializer - remove change to domain_create for dom0 (useless) - make construct_domU return error Changes in v3: - move patch earlier and introduce empty construct_domU to fix bisection builds - fix max_init_domid to actually hold the max domid among initial domains (instead of max_domid + 1) - move domain_unpause_by_systemcontroller(dom0) after creating domUs Changes in v2: - coding style - set nr_spis to 32 - introduce create_domUs --- xen/arch/arm/domain_build.c | 50 +++++++++++++++++++++++++++++++++++++++++---- xen/arch/arm/setup.c | 5 +++++ xen/include/asm-arm/setup.h | 3 +++ xen/include/asm-x86/setup.h | 2 ++ 4 files changed, 56 insertions(+), 4 deletions(-) diff --git a/xen/arch/arm/domain_build.c b/xen/arch/arm/domain_build.c index d1dab5a..93e9510 100644 --- a/xen/arch/arm/domain_build.c +++ b/xen/arch/arm/domain_build.c @@ -7,6 +7,7 @@ #include <asm/irq.h> #include <asm/regs.h> #include <xen/errno.h> +#include <xen/err.h> #include <xen/device_tree.h> #include <xen/libfdt/libfdt.h> #include <xen/guest_access.h> @@ -2304,6 +2305,50 @@ static int __init construct_domain(struct domain *d, struct kernel_info *kinfo) return 0; } +static int __init construct_domU(struct domain *d, + const struct dt_device_node *node) +{ + return -ENOSYS; +} + +void __init create_domUs(void) +{ + struct dt_device_node *node; + const struct dt_device_node *chosen = dt_find_node_by_path("/chosen"); + + BUG_ON(chosen == NULL); + dt_for_each_child_node(chosen, node) + { + struct domain *d; + struct xen_domctl_createdomain d_cfg = { + .arch.gic_version = XEN_DOMCTL_CONFIG_GIC_NATIVE, + .arch.nr_spis = 0, + .max_vcpus = 1, + .max_evtchn_port = -1, + .max_grant_frames = 64, + .max_maptrack_frames = 1024, + }; + + if ( !dt_device_is_compatible(node, "xen,domain") ) + continue; + + if ( dt_property_read_bool(node, "vpl011") ) + d_cfg.arch.nr_spis = GUEST_VPL011_SPI - 32 + 1; + dt_property_read_u32(node, "cpus", &d_cfg.max_vcpus); + + d = domain_create(++max_init_domid, &d_cfg, false); + if ( IS_ERR(d) ) + panic("Error creating domain %s", dt_node_name(node)); + + d->is_console = true; + + if ( construct_domU(d, node) != 0 ) + panic("Could not set up domain %s", dt_node_name(node)); + + domain_unpause_by_systemcontroller(d); + } +} + int __init construct_dom0(struct domain *d) { const struct bootcmdline *kernel = boot_cmdline_find_by_kind(BOOTMOD_KERNEL); @@ -2356,10 +2401,7 @@ int __init construct_dom0(struct domain *d) if ( rc < 0 ) return rc; - rc = construct_domain(d, &kinfo); - discard_initial_modules(); - - return rc; + return construct_domain(d, &kinfo); } /* diff --git a/xen/arch/arm/setup.c b/xen/arch/arm/setup.c index f3dc96c..43eb208 100644 --- a/xen/arch/arm/setup.c +++ b/xen/arch/arm/setup.c @@ -64,11 +64,14 @@ static unsigned long opt_xenheap_megabytes __initdata; integer_param("xenheap_megabytes", opt_xenheap_megabytes); #endif +domid_t __read_mostly max_init_domid; + static __used void init_done(void) { /* Must be done past setting system_state. */ unregister_init_virtual_region(); + discard_initial_modules(); free_init_memory(); startup_cpu_idle_loop(); } @@ -958,6 +961,8 @@ void __init start_xen(unsigned long boot_phys_offset, system_state = SYS_STATE_active; + create_domUs(); + domain_unpause_by_systemcontroller(dom0); /* Switch on to the dynamically allocated stack for the idle vcpu diff --git a/xen/include/asm-arm/setup.h b/xen/include/asm-arm/setup.h index 33fb04e..3071ba8 100644 --- a/xen/include/asm-arm/setup.h +++ b/xen/include/asm-arm/setup.h @@ -74,6 +74,8 @@ struct bootinfo { extern struct bootinfo bootinfo; +extern domid_t max_init_domid; + void arch_init_memory(void); void copy_from_paddr(void *dst, paddr_t paddr, unsigned long len); @@ -90,6 +92,7 @@ void acpi_create_efi_mmap_table(struct domain *d, int acpi_make_efi_nodes(void *fdt, struct membank tbl_add[]); int construct_dom0(struct domain *d); +void __init create_domUs(void); void discard_initial_modules(void); void dt_unreserved_regions(paddr_t s, paddr_t e, diff --git a/xen/include/asm-x86/setup.h b/xen/include/asm-x86/setup.h index 42fddeb..1c80783 100644 --- a/xen/include/asm-x86/setup.h +++ b/xen/include/asm-x86/setup.h @@ -66,4 +66,6 @@ extern bool opt_dom0_shadow; #endif extern bool dom0_pvh; +#define max_init_domid (0) + #endif -- 1.9.1 _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxxxxxxxxx https://lists.xenproject.org/mailman/listinfo/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |