From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756698AbcCBA53 (ORCPT ); Tue, 1 Mar 2016 19:57:29 -0500 Received: from mga09.intel.com ([134.134.136.24]:55905 "EHLO mga09.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754826AbcCAX4X (ORCPT ); Tue, 1 Mar 2016 18:56:23 -0500 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.22,524,1449561600"; d="scan'208";a="662136468" Subject: Re: [PATCH v3 9/9] x86/xsaves: Re-enable XSAVES To: Yu-cheng Yu , x86@kernel.org, "H. Peter Anvin" , Thomas Gleixner , Ingo Molnar , linux-kernel@vger.kernel.org References: <787ba3e73f657b06c02464ae522a47905ed503b8.1456524359.git.yu-cheng.yu@intel.com> Cc: Andy Lutomirski , Borislav Petkov , Sai Praneeth Prakhya , "Ravi V. Shankar" , Fenghua Yu From: Dave Hansen Message-ID: <56D62C1C.3050806@linux.intel.com> Date: Tue, 1 Mar 2016 15:56:12 -0800 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:38.0) Gecko/20100101 Thunderbird/38.5.1 MIME-Version: 1.0 In-Reply-To: <787ba3e73f657b06c02464ae522a47905ed503b8.1456524359.git.yu-cheng.yu@intel.com> Content-Type: text/plain; charset=windows-1252 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 02/29/2016 09:42 AM, Yu-cheng Yu wrote: > /* > - * Quirk: we don't yet handle the XSAVES* instructions > - * correctly, as we don't correctly convert between > - * standard and compacted format when interfacing > - * with user-space - so disable it for now. > - * > - * The difference is small: with recent CPUs the > - * compacted format is only marginally smaller than > - * the standard FPU state format. > - * > - * ( This is easy to backport while we are fixing > - * XSAVES* support. ) > + * Most recent CPUs supporting XSAVES can run 64-bit mode. > + * Enable XSAVES for 64-bit. > */ > - setup_clear_cpu_cap(X86_FEATURE_XSAVES); > + if (!config_enabled(CONFIG_X86_64)) > + setup_clear_cpu_cap(X86_FEATURE_XSAVES); > } I think we need a much better explanation of this for posterity. Why are we not supporting this now, and what would someone have to do in the future in order to enable it? > /* > diff --git a/arch/x86/kernel/fpu/xstate.c b/arch/x86/kernel/fpu/xstate.c > index 2e80d6f..cb2a484 100644 > --- a/arch/x86/kernel/fpu/xstate.c > +++ b/arch/x86/kernel/fpu/xstate.c > @@ -204,6 +204,14 @@ void fpu__init_cpu_xstate(void) > if (!cpu_has_xsave || !xfeatures_mask) > return; > > + /* > + * Make it clear that XSAVES supervisor states are not yet > + * implemented should anyone expect it to work by changing > + * bits in XFEATURE_MASK_* macros and XCR0. > + */ > + WARN_ONCE((xfeatures_mask & XFEATURE_MASK_SUPERVISOR), > + "x86/fpu: XSAVES supervisor states are not yet implemented.\n"); > + > cr4_set_bits(X86_CR4_OSXSAVE); > xsetbv(XCR_XFEATURE_ENABLED_MASK, xfeatures_mask); > } Let's also do a: xfeatures_mask &= ~XFEATURE_MASK_SUPERVISOR; Otherwise, we have a broken system at the moment.