[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [RFCv2 12/38] x86/hyperlaunch: move page computation to domain builder
The function dom_compute_nr_pages() is being moved to the domain builder. For this to happen, the variable dom0_nodes, and the functions calculate_dom0_pages() and dom0_pv_restrict_pages() must be exported. Signed-off-by: Daniel P. Smith <dpsmith@xxxxxxxxxxxxxxxxxxxx> --- xen/arch/x86/dom0_build.c | 75 +---------------------- xen/arch/x86/domain-builder/domain.c | 71 +++++++++++++++++++++ xen/arch/x86/include/asm/dom0_build.h | 4 +- xen/arch/x86/include/asm/domain-builder.h | 4 ++ 4 files changed, 81 insertions(+), 73 deletions(-) diff --git a/xen/arch/x86/dom0_build.c b/xen/arch/x86/dom0_build.c index 2a22cd4e125e..75969887b933 100644 --- a/xen/arch/x86/dom0_build.c +++ b/xen/arch/x86/dom0_build.c @@ -209,7 +209,7 @@ static int __init cf_check parse_dom0_nodes(const char *s) custom_param("dom0_nodes", parse_dom0_nodes); cpumask_t __initdata dom0_cpus; -static nodemask_t __initdata dom0_nodes; +nodemask_t __initdata dom0_nodes; unsigned int __init dom0_max_vcpus(void) { @@ -315,8 +315,7 @@ static unsigned long __init default_nr_pages(unsigned long avail) : min(avail / 16, 128UL << (20 - PAGE_SHIFT))); } -static void __init calculate_dom0_pages( - struct boot_domain *bd, unsigned long avail) +void __init calculate_dom0_pages(struct boot_domain *bd, unsigned long avail) { unsigned long nr_pages = bd->mem_pages ?: default_nr_pages(avail); @@ -338,7 +337,7 @@ static void __init calculate_dom0_pages( bd->mem_pages = nr_pages; } -static void __init dom0_pv_restrict_pages( +void __init dom0_pv_restrict_pages( struct boot_domain *bd, struct elf_dom_parms *parms) { if ( (parms->p2m_base == UNSET_ADDR) && !memsize_gt_zero(&dom0_size) && @@ -377,74 +376,6 @@ static void __init dom0_pv_restrict_pages( } } -unsigned long __init dom_compute_nr_pages( - struct boot_domain *bd, struct elf_dom_parms *parms) -{ - nodeid_t node; - nodemask_t nodes = { 0 }; - struct domain *d = bd->d; - unsigned long avail = 0, iommu_pages = 0; - - nodes_or(nodes, nodes, node_online_map); - - /* If building dom0 or hwdom, apply command line restriction. */ - if ( has_dom0_caps(bd) ) - nodes_and(nodes, nodes, dom0_nodes); - - ASSERT(nodes_weight(nodes) != 0); - - for_each_node_mask ( node, nodes ) - avail += avail_domheap_pages_region(node, 0, 0) + - initial_images_nrpages(node); - - /* Reserve memory for further dom0 vcpu-struct allocations... */ - avail -= (d->max_vcpus - 1UL) - << get_order_from_bytes(sizeof(struct vcpu)); - /* ...and compat_l4's, if needed. */ - if ( is_pv_32bit_domain(d) ) - avail -= d->max_vcpus - 1; - - /* Reserve memory for iommu_dom0_init() (rough estimate). */ - if ( is_hardware_domain(d) && is_iommu_enabled(d) - && !iommu_hwdom_passthrough ) - { - unsigned int s; - - for ( s = 9; s < BITS_PER_LONG; s += 9 ) - iommu_pages += max_pdx >> s; - - avail -= iommu_pages; - } - - if ( paging_mode_enabled(d) || opt_dom0_shadow || opt_pv_l1tf_hwdom ) - { - unsigned long cpu_pages; - - /* - * Clamp according to min/max limits and available memory - * (preliminary). - */ - calculate_dom0_pages(bd, avail); - - cpu_pages = dom_paging_pages(bd, bd->mem_pages); - - if ( !iommu_use_hap_pt(d) ) - avail -= cpu_pages; - else if ( cpu_pages > iommu_pages ) - avail -= cpu_pages - iommu_pages; - } - - /* Clamp according to min/max limits and available memory (final). */ - calculate_dom0_pages(bd, avail); - - if ( is_pv_domain(d) ) - dom0_pv_restrict_pages(bd, parms); - - d->max_pages = min_t(unsigned long, bd->max_pages, UINT_MAX); - - return bd->mem_pages; -} - static void __init process_dom0_ioports_disable(struct domain *dom0) { unsigned long io_from, io_to; diff --git a/xen/arch/x86/domain-builder/domain.c b/xen/arch/x86/domain-builder/domain.c index a2e5807b60a5..258f777cd9ee 100644 --- a/xen/arch/x86/domain-builder/domain.c +++ b/xen/arch/x86/domain-builder/domain.c @@ -6,6 +6,9 @@ #include <xen/cpumask.h> #include <xen/domain.h> #include <xen/init.h> +#include <xen/lib.h> /* get types.h for libefl.h */ +#include <xen/libelf.h> +#include <xen/nodemask.h> #include <xen/sched.h> #include <public/bootfdt.h> @@ -60,6 +63,74 @@ unsigned long __init dom_paging_pages( return DIV_ROUND_UP(memkb, 1024) << (20 - PAGE_SHIFT); } +unsigned long __init dom_compute_nr_pages( + struct boot_domain *bd, struct elf_dom_parms *parms) +{ + nodeid_t node; + nodemask_t nodes = { 0 }; + struct domain *d = bd->d; + unsigned long avail = 0, iommu_pages = 0; + + nodes_or(nodes, nodes, node_online_map); + + /* If building dom0 or hwdom, apply command line restriction. */ + if ( has_dom0_caps(bd) ) + nodes_and(nodes, nodes, dom0_nodes); + + ASSERT(nodes_weight(nodes) != 0); + + for_each_node_mask ( node, nodes ) + avail += avail_domheap_pages_region(node, 0, 0) + + initial_images_nrpages(node); + + /* Reserve memory for further dom0 vcpu-struct allocations... */ + avail -= (d->max_vcpus - 1UL) + << get_order_from_bytes(sizeof(struct vcpu)); + /* ...and compat_l4's, if needed. */ + if ( is_pv_32bit_domain(d) ) + avail -= d->max_vcpus - 1; + + /* Reserve memory for iommu_dom0_init() (rough estimate). */ + if ( is_hardware_domain(d) && is_iommu_enabled(d) + && !iommu_hwdom_passthrough ) + { + unsigned int s; + + for ( s = 9; s < BITS_PER_LONG; s += 9 ) + iommu_pages += max_pdx >> s; + + avail -= iommu_pages; + } + + if ( paging_mode_enabled(d) || opt_dom0_shadow || opt_pv_l1tf_hwdom ) + { + unsigned long cpu_pages; + + /* + * Clamp according to min/max limits and available memory + * (preliminary). + */ + calculate_dom0_pages(bd, avail); + + cpu_pages = dom_paging_pages(bd, bd->mem_pages); + + if ( !iommu_use_hap_pt(d) ) + avail -= cpu_pages; + else if ( cpu_pages > iommu_pages ) + avail -= cpu_pages - iommu_pages; + } + + /* Clamp according to min/max limits and available memory (final). */ + calculate_dom0_pages(bd, avail); + + if ( is_pv_domain(d) ) + dom0_pv_restrict_pages(bd, parms); + + d->max_pages = min_t(unsigned long, bd->max_pages, UINT_MAX); + + return bd->mem_pages; +} + /* * Local variables: * mode: C diff --git a/xen/arch/x86/include/asm/dom0_build.h b/xen/arch/x86/include/asm/dom0_build.h index 7275bcf9ba6b..43a402af15b7 100644 --- a/xen/arch/x86/include/asm/dom0_build.h +++ b/xen/arch/x86/include/asm/dom0_build.h @@ -7,13 +7,15 @@ #include <asm/setup.h> extern unsigned int dom0_memflags; +extern nodemask_t dom0_nodes; void dom0_set_affinity(struct domain *dom0); int dom0_setup_permissions(struct domain *d); struct boot_domain; -unsigned long dom_compute_nr_pages( +void calculate_dom0_pages(struct boot_domain *bd, unsigned long avail); +void dom0_pv_restrict_pages( struct boot_domain *bd, struct elf_dom_parms *parms); int dom0_construct_pv(struct boot_domain *bd); diff --git a/xen/arch/x86/include/asm/domain-builder.h b/xen/arch/x86/include/asm/domain-builder.h index c5a71fae5ccb..243ca09c045a 100644 --- a/xen/arch/x86/include/asm/domain-builder.h +++ b/xen/arch/x86/include/asm/domain-builder.h @@ -2,10 +2,14 @@ #define __XEN_X86_DOMBUILDER_H__ struct boot_domain; +struct elf_dom_parms; unsigned long dom_paging_pages( const struct boot_domain *d, unsigned long nr_pages); +unsigned long dom_compute_nr_pages( + struct boot_domain *bd, struct elf_dom_parms *parms); + int dom_construct_pvh(struct boot_domain *bd); #endif -- 2.30.2
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |