From: Razvan Cojocaru Date: Thu, 28 Jun 2018 07:54:01 +0000 (+0300) Subject: xen/altp2m: set access_required properly for all altp2ms X-Git-Tag: archive/raspbian/4.14.0+80-gd101b417b7-1+rpi1^2~63^2~3561 X-Git-Url: https://dgit.raspbian.org/?a=commitdiff_plain;h=61bdddb82151fbf51c58f6ebc1b4a687942c45a8;p=xen.git xen/altp2m: set access_required properly for all altp2ms For the hostp2m, access_required starts off as 0, then it can be set with xc_domain_set_access_required(). However, all the altp2ms set it to 1 on init, and ignore both the hostp2m and the hypercall. This patch sets access_required to the value from the hostp2m on altp2m init, and propagates the values received via hypercall to all the active altp2ms, when applicable. Signed-off-by: Razvan Cojocaru Acked-by: Tamas K Lengyel Reviewed-by: George Dunlap Acked-by: Julien Grall --- diff --git a/xen/arch/arm/mem_access.c b/xen/arch/arm/mem_access.c index ae2686ffa2..ba4ec780fd 100644 --- a/xen/arch/arm/mem_access.c +++ b/xen/arch/arm/mem_access.c @@ -453,6 +453,12 @@ int p2m_get_mem_access(struct domain *d, gfn_t gfn, return ret; } +void arch_p2m_set_access_required(struct domain *d, bool access_required) +{ + ASSERT(atomic_read(&d->pause_count)); + p2m_get_hostp2m(d)->access_required = access_required; +} + /* * Local variables: * mode: C diff --git a/xen/arch/x86/mm/mem_access.c b/xen/arch/x86/mm/mem_access.c index febe38d8df..03a8641569 100644 --- a/xen/arch/x86/mm/mem_access.c +++ b/xen/arch/x86/mm/mem_access.c @@ -474,6 +474,26 @@ int p2m_get_mem_access(struct domain *d, gfn_t gfn, xenmem_access_t *access) return _p2m_get_mem_access(p2m, gfn, access); } +void arch_p2m_set_access_required(struct domain *d, bool access_required) +{ + unsigned int i; + + ASSERT(atomic_read(&d->pause_count)); + + p2m_get_hostp2m(d)->access_required = access_required; + + if ( !altp2m_active(d) ) + return; + + for ( i = 0; i < MAX_ALTP2M; i++ ) + { + struct p2m_domain *p2m = d->arch.altp2m_p2m[i]; + + if ( p2m ) + p2m->access_required = access_required; + } +} + /* * Local variables: * mode: C diff --git a/xen/arch/x86/mm/p2m.c b/xen/arch/x86/mm/p2m.c index c53cab44d9..8e9fbb5a14 100644 --- a/xen/arch/x86/mm/p2m.c +++ b/xen/arch/x86/mm/p2m.c @@ -199,6 +199,7 @@ static int p2m_init_altp2m(struct domain *d) { unsigned int i; struct p2m_domain *p2m; + struct p2m_domain *hostp2m = p2m_get_hostp2m(d); mm_lock_init(&d->arch.altp2m_list_lock); for ( i = 0; i < MAX_ALTP2M; i++ ) @@ -210,7 +211,7 @@ static int p2m_init_altp2m(struct domain *d) return -ENOMEM; } p2m->p2m_class = p2m_alternate; - p2m->access_required = 1; + p2m->access_required = hostp2m->access_required; _atomic_set(&p2m->active_vcpus, 0); } diff --git a/xen/common/domctl.c b/xen/common/domctl.c index 39eb819ce1..a1d7270910 100644 --- a/xen/common/domctl.c +++ b/xen/common/domctl.c @@ -1092,8 +1092,8 @@ long do_domctl(XEN_GUEST_HANDLE_PARAM(xen_domctl_t) u_domctl) else { domain_pause(d); - p2m_get_hostp2m(d)->access_required = - op->u.access_required.access_required; + arch_p2m_set_access_required(d, + op->u.access_required.access_required); domain_unpause(d); } break; diff --git a/xen/include/xen/domain.h b/xen/include/xen/domain.h index 177cb3521a..f35e3607d3 100644 --- a/xen/include/xen/domain.h +++ b/xen/include/xen/domain.h @@ -66,6 +66,8 @@ void arch_domain_unpause(struct domain *d); int arch_domain_soft_reset(struct domain *d); +void arch_p2m_set_access_required(struct domain *d, bool access_required); + int arch_set_info_guest(struct vcpu *, vcpu_guest_context_u); void arch_get_info_guest(struct vcpu *, vcpu_guest_context_u);