On 09/07/2015 10:17, Richard Henderson wrote:
> +
> +    /* ??? This variable is somewhat silly.  Methinks KVM should be
> +       using XCR0 to store into the XSTATE_BV field.  Either that or
> +       there's more missing information, e.g. the AVX bits.  */
> +    env->xstate_bv = XSTATE_FP;
> +    if (env->features[FEAT_1_EDX] & CPUID_SSE) {
> +        env->xstate_bv |= XSTATE_SSE;
> +    }
> +    if (env->features[FEAT_7_0_EBX] & CPUID_7_0_EBX_MPX) {
> +        env->xstate_bv |= XSTATE_BNDREGS | XSTATE_BNDCSR;
> +    }

xstate_bv != xcr0 if the kernel is using XSAVEOPT and some of the values
were in the initial state.  Legacy state is never optimized, hence the
value of env->xstate_bv after reset.  So I think this hunk is wrong,
while the other is correct.

Paolo

Reply via email to