From: Alexandru Isaila Date: Mon, 10 Sep 2018 14:26:00 +0000 (+0200) Subject: x86/hvm: introduce hvm_save_cpu_xsave_states_one() X-Git-Tag: archive/raspbian/4.14.0+80-gd101b417b7-1+rpi1^2~63^2~3281 X-Git-Url: https://dgit.raspbian.org/?a=commitdiff_plain;h=653abbb8144bfbff69b8bbc383f20d7dfaf03fcb;p=xen.git x86/hvm: introduce hvm_save_cpu_xsave_states_one() This is used to save data from a single instance. Signed-off-by: Alexandru Isaila Reviewed-by: Jan Beulich --- diff --git a/xen/arch/x86/hvm/hvm.c b/xen/arch/x86/hvm/hvm.c index 056c6cd7f1..c92c952b46 100644 --- a/xen/arch/x86/hvm/hvm.c +++ b/xen/arch/x86/hvm/hvm.c @@ -1163,35 +1163,46 @@ HVM_REGISTER_SAVE_RESTORE(CPU, hvm_save_cpu_ctxt, hvm_load_cpu_ctxt, save_area) + \ xstate_ctxt_size(xcr0)) -static int hvm_save_cpu_xsave_states(struct domain *d, hvm_domain_context_t *h) +static int hvm_save_cpu_xsave_states_one(struct vcpu *v, hvm_domain_context_t *h) { - struct vcpu *v; struct hvm_hw_cpu_xsave *ctxt; + unsigned int size = HVM_CPU_XSAVE_SIZE(v->arch.xcr0_accum); + int err; - if ( !cpu_has_xsave ) + if ( !cpu_has_xsave || !xsave_enabled(v) ) return 0; /* do nothing */ - for_each_vcpu ( d, v ) - { - unsigned int size = HVM_CPU_XSAVE_SIZE(v->arch.xcr0_accum); + err = _hvm_init_entry(h, CPU_XSAVE_CODE, v->vcpu_id, size); + if ( err ) + return err; - if ( !xsave_enabled(v) ) - continue; - if ( _hvm_init_entry(h, CPU_XSAVE_CODE, v->vcpu_id, size) ) - return 1; - ctxt = (struct hvm_hw_cpu_xsave *)&h->data[h->cur]; - h->cur += size; + ctxt = (struct hvm_hw_cpu_xsave *)&h->data[h->cur]; + h->cur += size; + ctxt->xfeature_mask = xfeature_mask; + ctxt->xcr0 = v->arch.xcr0; + ctxt->xcr0_accum = v->arch.xcr0_accum; - ctxt->xfeature_mask = xfeature_mask; - ctxt->xcr0 = v->arch.xcr0; - ctxt->xcr0_accum = v->arch.xcr0_accum; - expand_xsave_states(v, &ctxt->save_area, - size - offsetof(typeof(*ctxt), save_area)); - } + expand_xsave_states(v, &ctxt->save_area, + size - offsetof(typeof(*ctxt), save_area)); return 0; } +static int hvm_save_cpu_xsave_states(struct domain *d, hvm_domain_context_t *h) +{ + struct vcpu *v; + int err = 0; + + for_each_vcpu ( d, v ) + { + err = hvm_save_cpu_xsave_states_one(v, h); + if ( err ) + break; + } + + return err; +} + /* * Structure layout conformity checks, documenting correctness of the cast in * the invocation of validate_xstate() below.