]> xenbits.xensource.com Git - people/andrewcoop/xen.git/commitdiff
x86/FPU: make vcpu_reset_fpu() build with old gcc
authorJan Beulich <jbeulich@suse.com>
Tue, 10 Dec 2024 17:03:38 +0000 (18:03 +0100)
committerJan Beulich <jbeulich@suse.com>
Tue, 10 Dec 2024 17:03:38 +0000 (18:03 +0100)
Fields of anonymous structs/unions may not be part of an initializer for
rather old gcc (4.6 and earlier).

Fixes: 49a068471d77 ("x86/fpu: Rework fpu_setup_fpu() uses to split it in two")
Signed-off-by: Jan Beulich <jbeulich@suse.com>
Reviewed-by: Alejandro Vallejo <alejandro.vallejo@cloud.com>
xen/arch/x86/i387.c

index 3add0025e49524936721d69c99e2e5bdf9b92858..8fba0aef4284a1d1967f3ae3c6eac060e8c77443 100644 (file)
@@ -306,13 +306,13 @@ void vcpu_reset_fpu(struct vcpu *v)
 {
     v->fpu_initialised = false;
     *v->arch.xsave_area = (struct xsave_struct) {
-        .fpu_sse = {
-            .mxcsr = MXCSR_DEFAULT,
-            .fcw = FCW_RESET,
-            .ftw = FXSAVE_FTW_RESET,
-        },
         .xsave_hdr.xstate_bv = X86_XCR0_X87,
     };
+
+    /* Old gcc doesn't permit these to be part of the initializer. */
+    v->arch.xsave_area->fpu_sse.mxcsr = MXCSR_DEFAULT;
+    v->arch.xsave_area->fpu_sse.fcw = FCW_RESET;
+    v->arch.xsave_area->fpu_sse.ftw = FXSAVE_FTW_RESET;
 }
 
 void vcpu_setup_fpu(struct vcpu *v, const void *data)