aboutsummaryrefslogtreecommitdiff
path: root/arch/powerpc/mm
diff options
context:
space:
mode:
authorGravatar Christophe Leroy <christophe.leroy@csgroup.eu> 2021-10-19 09:29:30 +0200
committerGravatar Michael Ellerman <mpe@ellerman.id.au> 2021-12-09 22:41:20 +1100
commitfcf9bb6d32f8a268bc3daf3281e3beefabec4e7c (patch)
tree65270cd8f92d4809d2e073cb07da6897ce55bcd8 /arch/powerpc/mm
parentpowerpc/kuap: Wire-up KUAP on 44x (diff)
downloadlinux-fcf9bb6d32f8a268bc3daf3281e3beefabec4e7c.tar.gz
linux-fcf9bb6d32f8a268bc3daf3281e3beefabec4e7c.tar.bz2
linux-fcf9bb6d32f8a268bc3daf3281e3beefabec4e7c.zip
powerpc/kuap: Wire-up KUAP on 40x
This adds KUAP support to 40x. This is done by checking the content of SPRN_PID at the time user pgtable is loaded. 40x doesn't have KUEP, but KUAP implies KUEP because when the PID doesn't match the page's PID, the page cannot be read nor executed. So KUEP is now automatically selected when KUAP is selected and disabled when KUAP is disabled. Signed-off-by: Christophe Leroy <christophe.leroy@csgroup.eu> Signed-off-by: Michael Ellerman <mpe@ellerman.id.au> Link: https://lore.kernel.org/r/aaefa91897ddc42ac11019dc0e1d1a525bd08e90.1634627931.git.christophe.leroy@csgroup.eu
Diffstat (limited to 'arch/powerpc/mm')
-rw-r--r--arch/powerpc/mm/nohash/kup.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/arch/powerpc/mm/nohash/kup.c b/arch/powerpc/mm/nohash/kup.c
index eaea52231dd6..552becf90e97 100644
--- a/arch/powerpc/mm/nohash/kup.c
+++ b/arch/powerpc/mm/nohash/kup.c
@@ -19,6 +19,8 @@ EXPORT_SYMBOL(disable_kuap_key);
void setup_kuap(bool disabled)
{
if (disabled) {
+ if (IS_ENABLED(CONFIG_40x))
+ disable_kuep = true;
if (smp_processor_id() == boot_cpuid)
static_branch_enable(&disable_kuap_key);
return;