MSR_F15H_PERF_CTL3, MSR_F15H_PERF_CTL4, MSR_F15H_PERF_CTL5,
        MSR_F15H_PERF_CTR0, MSR_F15H_PERF_CTR1, MSR_F15H_PERF_CTR2,
        MSR_F15H_PERF_CTR3, MSR_F15H_PERF_CTR4, MSR_F15H_PERF_CTR5,
+       MSR_IA32_XFD,
 };
 
 static u32 msrs_to_save[ARRAY_SIZE(msrs_to_save_all)];
                        return 1;
                vcpu->arch.msr_misc_features_enables = data;
                break;
+#ifdef CONFIG_X86_64
+       case MSR_IA32_XFD:
+               if (!msr_info->host_initiated &&
+                   !guest_cpuid_has(vcpu, X86_FEATURE_XFD))
+                       return 1;
+
+               if (data & ~(XFEATURE_MASK_USER_DYNAMIC &
+                            vcpu->arch.guest_supported_xcr0))
+                       return 1;
+
+               fpu_update_guest_xfd(&vcpu->arch.guest_fpu, data);
+               break;
+#endif
        default:
                if (kvm_pmu_is_valid_msr(vcpu, msr))
                        return kvm_pmu_set_msr(vcpu, msr_info);
        case MSR_K7_HWCR:
                msr_info->data = vcpu->arch.msr_hwcr;
                break;
+#ifdef CONFIG_X86_64
+       case MSR_IA32_XFD:
+               if (!msr_info->host_initiated &&
+                   !guest_cpuid_has(vcpu, X86_FEATURE_XFD))
+                       return 1;
+
+               msr_info->data = vcpu->arch.guest_fpu.fpstate->xfd;
+               break;
+#endif
        default:
                if (kvm_pmu_is_valid_msr(vcpu, msr_info->index))
                        return kvm_pmu_get_msr(vcpu, msr_info);
                            min(INTEL_PMC_MAX_GENERIC, x86_pmu.num_counters_gp))
                                continue;
                        break;
+               case MSR_IA32_XFD:
+                       if (!kvm_cpu_cap_has(X86_FEATURE_XFD))
+                               continue;
+                       break;
                default:
                        break;
                }