Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752029AbbLHStJ (ORCPT ); Tue, 8 Dec 2015 13:49:09 -0500 Received: from www.linutronix.de ([62.245.132.108]:51836 "EHLO Galois.linutronix.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751889AbbLHStH (ORCPT ); Tue, 8 Dec 2015 13:49:07 -0500 Date: Tue, 8 Dec 2015 19:48:19 +0100 (CET) From: Thomas Gleixner To: Dave Hansen cc: linux-kernel@vger.kernel.org, linux-mm@kvack.org, x86@kernel.org, dave.hansen@linux.intel.com Subject: Re: [PATCH 30/34] x86, fpu: allow setting of XSAVE state In-Reply-To: <20151204011506.7A3C77FA@viggo.jf.intel.com> Message-ID: References: <20151204011424.8A36E365@viggo.jf.intel.com> <20151204011506.7A3C77FA@viggo.jf.intel.com> User-Agent: Alpine 2.11 (DEB 23 2013-08-11) MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII X-Linutronix-Spam-Score: -1.0 X-Linutronix-Spam-Level: - X-Linutronix-Spam-Status: No , -1.0 points, 5.0 required, ALL_TRUSTED=-1,SHORTCIRCUIT=-0.0001,URIBL_BLOCKED=0.001 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1144 Lines: 29 On Thu, 3 Dec 2015, Dave Hansen wrote: > > From: Dave Hansen > > We want to modify the Protection Key rights inside the kernel, so > we need to change PKRU's contents. But, if we do a plain > 'wrpkru', when we return to userspace we might do an XRSTOR and > wipe out the kernel's 'wrpkru'. So, we need to go after PKRU in > the xsave buffer. > > We do this by: > 1. Ensuring that we have the XSAVE registers (fpregs) in the > kernel FPU buffer (fpstate) > 2. Looking up the location of a given state in the buffer > 3. Filling in the stat > 4. Ensuring that the hardware knows that state is present there > (basically that the 'init optimization' is not in place). > 5. Copying the newly-modified state back to the registers if > necessary. > > Signed-off-by: Dave Hansen Reviewed-by: Thomas Gleixner -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/