|
[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 |