[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [RFCv2 36/38] x86/hyperlaunch: enable unpausing mulitple domains
This commit enables the domain builder to unpause all domains that have been flagged to start on boot. Signed-off-by: Daniel P. Smith <dpsmith@xxxxxxxxxxxxxxxxxxxx> --- xen/arch/x86/domain-builder/core.c | 20 ++++++++++++++++++++ xen/arch/x86/include/asm/boot-domain.h | 8 +++++--- xen/arch/x86/setup.c | 8 +++++++- xen/include/xen/domain-builder.h | 1 + 4 files changed, 33 insertions(+), 4 deletions(-) diff --git a/xen/arch/x86/domain-builder/core.c b/xen/arch/x86/domain-builder/core.c index 367c0de33cfb..dbe547ff0a87 100644 --- a/xen/arch/x86/domain-builder/core.c +++ b/xen/arch/x86/domain-builder/core.c @@ -7,6 +7,7 @@ #include <xen/domain-builder.h> #include <xen/init.h> #include <xen/lib.h> +#include <xen/sched.h> #include <asm/bootinfo.h> #include <asm/pv/shim.h> @@ -109,6 +110,25 @@ unsigned int __init builder_create_domains(struct boot_info *bi) return build_count; } +int __init builder_unpause_domains(struct boot_info *bi) +{ + int i, count = 0; + + for ( i = 0; i < bi->nr_domains; i++ ) + { + struct boot_domain *bd = &bi->domains[i]; + + if ( bd->capabilities & DOMAIN_CAPS_HARDWARE || + bd->mode & BUILD_MODE_START_ON_BOOT ) + { + domain_unpause_by_systemcontroller(bd->d); + count++; + } + } + + return count; +} + /* * Local variables: * mode: C diff --git a/xen/arch/x86/include/asm/boot-domain.h b/xen/arch/x86/include/asm/boot-domain.h index 41246f31acce..b04d48010799 100644 --- a/xen/arch/x86/include/asm/boot-domain.h +++ b/xen/arch/x86/include/asm/boot-domain.h @@ -18,9 +18,11 @@ struct boot_domain { /* Bitmap. See DOMAIN_CAPS_MASK for a list */ uint32_t capabilities; - /* On | Off */ -#define BUILD_MODE_PARAVIRT (1 << 0) /* PV | PVH/HVM */ -#define BUILD_MODE_ENABLE_DM (1 << 1) /* HVM | PVH */ + /* On | Off */ +#define BUILD_MODE_PARAVIRT (1 << 0) /* PV | PVH/HVM */ +#define BUILD_MODE_ENABLE_DM (1 << 1) /* HVM | PVH */ +#define BUILD_MODE_LONG (1 << 2) /* 64 BIT | 32 BIT */ +#define BUILD_MODE_START_ON_BOOT (1 << 3) /* UNPAUSED | PAUSED */ uint32_t mode; unsigned long mem_pages; diff --git a/xen/arch/x86/setup.c b/xen/arch/x86/setup.c index 422fef7ce02a..b55a1da9db91 100644 --- a/xen/arch/x86/setup.c +++ b/xen/arch/x86/setup.c @@ -790,6 +790,7 @@ static inline bool using_2M_mapping(void) static void noreturn init_done(void) { + struct boot_info *bi = &xen_boot_info; void *va; unsigned long start, end; int err; @@ -803,7 +804,12 @@ static void noreturn init_done(void) if ( IS_ENABLED(CONFIG_SELF_TESTS) && cpu_has_xen_shstk ) stub_selftest(); - domain_unpause_by_systemcontroller(dom0); + err = builder_unpause_domains(bi); + if ( err == 0 ) + panic("domain builder: failed to schedule any domain to start\n"); + else + printk("domain builder: unpaused %d of %d domains at boot\n", err, + bi->nr_domains); /* MUST be done prior to removing .init data. */ unregister_init_virtual_region(); diff --git a/xen/include/xen/domain-builder.h b/xen/include/xen/domain-builder.h index ca9d9032b35b..eb8f5773b17e 100644 --- a/xen/include/xen/domain-builder.h +++ b/xen/include/xen/domain-builder.h @@ -46,5 +46,6 @@ struct domain *arch_create_dom( int arch_builder_finalize(struct boot_info *bi); unsigned int builder_create_domains(struct boot_info *bi); +int builder_unpause_domains(struct boot_info *bi); #endif /* __XEN_DOMAIN_BUILDER_H__ */ -- 2.30.2
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |