[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <alpine.DEB.2.11.1601082039570.3575@nanos>
Date: Fri, 8 Jan 2016 20:40:14 +0100 (CET)
From: Thomas Gleixner <tglx@...utronix.de>
To: Dave Hansen <dave@...1.net>
cc: linux-kernel@...r.kernel.org, linux-mm@...ck.org, x86@...nel.org,
dave.hansen@...ux.intel.com
Subject: Re: [PATCH 29/31] x86, pkeys: allow kernel to modify user pkey rights
register
On Wed, 6 Jan 2016, Dave Hansen wrote:
> From: Dave Hansen <dave.hansen@...ux.intel.com>
>
> The Protection Key Rights for User memory (PKRU) is a 32-bit
> user-accessible register. It contains two bits for each
> protection key: one to write-disable (WD) access to memory
> covered by the key and another to access-disable (AD).
>
> Userspace can read/write the register with the RDPKRU and WRPKRU
> instructions. But, the register is saved and restored with the
> XSAVE family of instructions, which means we have to treat it
> like a floating point register.
>
> The kernel needs to write to the register if it wants to
> implement execute-only memory or if it implements a system call
> to change PKRU.
>
> To do this, we need to create a 'pkru_state' buffer, read the old
> contents in to it, modify it, and then tell the FPU code that
> there is modified data in there so it can (possibly) move the
> buffer back in to the registers.
>
> This uses the fpu__xfeature_set_state() function that we defined
> in the previous patch.
>
> Signed-off-by: Dave Hansen <dave.hansen@...ux.intel.com>
Reviewed-by: Thomas Gleixner <tglx@...utronix.de>
Powered by blists - more mailing lists