[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] [xen master] viridian: define type for the 'virtual VP assist page'
commit 07ded9a515eb27765ca437167f5dc087901112de Author: Paul Durrant <paul.durrant@xxxxxxxxxx> AuthorDate: Fri Nov 9 11:39:27 2018 +0100 Commit: Jan Beulich <jbeulich@xxxxxxxx> CommitDate: Fri Nov 9 11:39:27 2018 +0100 viridian: define type for the 'virtual VP assist page' The specification [1] defines a type so we should use it, rather than just OR-ing and AND-ing magic bits. No functional change. NOTE: The type defined in the specification does include an anonymous sub-struct in the page type but, as we currently use only the first element, the struct declaration has been omitted. [1] https://github.com/MicrosoftDocs/Virtualization-Documentation/raw/live/tlfs/Hypervisor%20Top%20Level%20Functional%20Specification%20v5.0C.pdf Signed-off-by: Paul Durrant <paul.durrant@xxxxxxxxxx> Reviewed-by: Wei Liu <wei.liu2@xxxxxxxxxx> Reviewed-by: Roger Pau Monné <roger.pau@xxxxxxxxxx> --- xen/arch/x86/hvm/viridian/synic.c | 52 +++++++++++++++++++++++--------------- xen/include/asm-x86/hvm/viridian.h | 4 ++- 2 files changed, 35 insertions(+), 21 deletions(-) diff --git a/xen/arch/x86/hvm/viridian/synic.c b/xen/arch/x86/hvm/viridian/synic.c index 366608208f..d8d6f6e1c9 100644 --- a/xen/arch/x86/hvm/viridian/synic.c +++ b/xen/arch/x86/hvm/viridian/synic.c @@ -16,6 +16,18 @@ #include "private.h" +typedef struct _HV_VIRTUAL_APIC_ASSIST +{ + uint32_t no_eoi:1; + uint32_t reserved_zero:31; +} HV_VIRTUAL_APIC_ASSIST; + +union _HV_VP_ASSIST_PAGE +{ + HV_VIRTUAL_APIC_ASSIST ApicAssist; + uint8_t ReservedZBytePadding[PAGE_SIZE]; +}; + static void dump_vp_assist(const struct vcpu *v) { const union viridian_page_msr *va = &v->arch.hvm.viridian.vp_assist.msr; @@ -32,9 +44,9 @@ static void initialize_vp_assist(struct vcpu *v) struct domain *d = v->domain; unsigned long gmfn = v->arch.hvm.viridian.vp_assist.msr.fields.pfn; struct page_info *page = get_page_from_gfn(d, gmfn, NULL, P2M_ALLOC); - void *va; + HV_VP_ASSIST_PAGE *ptr; - ASSERT(!v->arch.hvm.viridian.vp_assist.va); + ASSERT(!v->arch.hvm.viridian.vp_assist.ptr); if ( !page ) goto fail; @@ -45,16 +57,16 @@ static void initialize_vp_assist(struct vcpu *v) goto fail; } - va = __map_domain_page_global(page); - if ( !va ) + ptr = __map_domain_page_global(page); + if ( !ptr ) { put_page_and_type(page); goto fail; } - clear_page(va); + clear_page(ptr); - v->arch.hvm.viridian.vp_assist.va = va; + v->arch.hvm.viridian.vp_assist.ptr = ptr; return; fail: @@ -64,25 +76,25 @@ static void initialize_vp_assist(struct vcpu *v) static void teardown_vp_assist(struct vcpu *v) { - void *va = v->arch.hvm.viridian.vp_assist.va; + HV_VP_ASSIST_PAGE *ptr = v->arch.hvm.viridian.vp_assist.ptr; struct page_info *page; - if ( !va ) + if ( !ptr ) return; - v->arch.hvm.viridian.vp_assist.va = NULL; + v->arch.hvm.viridian.vp_assist.ptr = NULL; - page = mfn_to_page(domain_page_map_to_mfn(va)); + page = mfn_to_page(domain_page_map_to_mfn(ptr)); - unmap_domain_page_global(va); + unmap_domain_page_global(ptr); put_page_and_type(page); } void viridian_apic_assist_set(struct vcpu *v) { - uint32_t *va = v->arch.hvm.viridian.vp_assist.va; + HV_VP_ASSIST_PAGE *ptr = v->arch.hvm.viridian.vp_assist.ptr; - if ( !va ) + if ( !ptr ) return; /* @@ -94,18 +106,18 @@ void viridian_apic_assist_set(struct vcpu *v) domain_crash(v->domain); v->arch.hvm.viridian.vp_assist.pending = true; - *va |= 1u; + ptr->ApicAssist.no_eoi = 1; } bool viridian_apic_assist_completed(struct vcpu *v) { - uint32_t *va = v->arch.hvm.viridian.vp_assist.va; + HV_VP_ASSIST_PAGE *ptr = v->arch.hvm.viridian.vp_assist.ptr; - if ( !va ) + if ( !ptr ) return false; if ( v->arch.hvm.viridian.vp_assist.pending && - !(*va & 1u) ) + !ptr->ApicAssist.no_eoi ) { /* An EOI has been avoided */ v->arch.hvm.viridian.vp_assist.pending = false; @@ -117,12 +129,12 @@ bool viridian_apic_assist_completed(struct vcpu *v) void viridian_apic_assist_clear(struct vcpu *v) { - uint32_t *va = v->arch.hvm.viridian.vp_assist.va; + HV_VP_ASSIST_PAGE *ptr = v->arch.hvm.viridian.vp_assist.ptr; - if ( !va ) + if ( !ptr ) return; - *va &= ~1u; + ptr->ApicAssist.no_eoi = 0; v->arch.hvm.viridian.vp_assist.pending = false; } diff --git a/xen/include/asm-x86/hvm/viridian.h b/xen/include/asm-x86/hvm/viridian.h index 5ff83a46e5..22f14a526e 100644 --- a/xen/include/asm-x86/hvm/viridian.h +++ b/xen/include/asm-x86/hvm/viridian.h @@ -20,11 +20,13 @@ union viridian_page_msr } fields; }; +typedef union _HV_VP_ASSIST_PAGE HV_VP_ASSIST_PAGE; + struct viridian_vcpu { struct { union viridian_page_msr msr; - void *va; + HV_VP_ASSIST_PAGE *ptr; bool pending; } vp_assist; uint64_t crash_param[5]; -- generated by git-patchbot for /home/xen/git/xen.git#master _______________________________________________ Xen-changelog mailing list Xen-changelog@xxxxxxxxxxxxxxxxxxxx https://lists.xenproject.org/xen-changelog
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |