lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
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

Powered by Openwall GNU/*/Linux Powered by OpenVZ