Commit f7045a45 authored by Aneesh Kumar K.V's avatar Aneesh Kumar K.V Committed by Michael Ellerman

powerpc/book3s64/pkeys: Use MMU_FTR_PKEY instead of pkey_disabled static key

Instead of pkey_disabled static key use mmu feature MMU_FTR_PKEY.
Signed-off-by: default avatarAneesh Kumar K.V <aneesh.kumar@linux.ibm.com>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/20200709032946.881753-17-aneesh.kumar@linux.ibm.com
parent 2daf298d
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
static inline u64 vmflag_to_pte_pkey_bits(u64 vm_flags) static inline u64 vmflag_to_pte_pkey_bits(u64 vm_flags)
{ {
if (static_branch_likely(&pkey_disabled)) if (!mmu_has_feature(MMU_FTR_PKEY))
return 0x0UL; return 0x0UL;
if (radix_enabled()) if (radix_enabled())
......
...@@ -11,7 +11,6 @@ ...@@ -11,7 +11,6 @@
#include <linux/jump_label.h> #include <linux/jump_label.h>
#include <asm/firmware.h> #include <asm/firmware.h>
DECLARE_STATIC_KEY_FALSE(pkey_disabled);
extern int num_pkey; extern int num_pkey;
extern u32 reserved_allocation_mask; /* bits set for reserved keys */ extern u32 reserved_allocation_mask; /* bits set for reserved keys */
...@@ -38,7 +37,7 @@ static inline u64 pkey_to_vmflag_bits(u16 pkey) ...@@ -38,7 +37,7 @@ static inline u64 pkey_to_vmflag_bits(u16 pkey)
static inline int vma_pkey(struct vm_area_struct *vma) static inline int vma_pkey(struct vm_area_struct *vma)
{ {
if (static_branch_likely(&pkey_disabled)) if (!mmu_has_feature(MMU_FTR_PKEY))
return 0; return 0;
return (vma->vm_flags & ARCH_VM_PKEY_FLAGS) >> VM_PKEY_SHIFT; return (vma->vm_flags & ARCH_VM_PKEY_FLAGS) >> VM_PKEY_SHIFT;
} }
...@@ -93,9 +92,8 @@ static inline int mm_pkey_alloc(struct mm_struct *mm) ...@@ -93,9 +92,8 @@ static inline int mm_pkey_alloc(struct mm_struct *mm)
u32 all_pkeys_mask = (u32)(~(0x0)); u32 all_pkeys_mask = (u32)(~(0x0));
int ret; int ret;
if (static_branch_likely(&pkey_disabled)) if (!mmu_has_feature(MMU_FTR_PKEY))
return -1; return -1;
/* /*
* Are we out of pkeys? We must handle this specially because ffz() * Are we out of pkeys? We must handle this specially because ffz()
* behavior is undefined if there are no zeros. * behavior is undefined if there are no zeros.
...@@ -111,7 +109,7 @@ static inline int mm_pkey_alloc(struct mm_struct *mm) ...@@ -111,7 +109,7 @@ static inline int mm_pkey_alloc(struct mm_struct *mm)
static inline int mm_pkey_free(struct mm_struct *mm, int pkey) static inline int mm_pkey_free(struct mm_struct *mm, int pkey)
{ {
if (static_branch_likely(&pkey_disabled)) if (!mmu_has_feature(MMU_FTR_PKEY))
return -1; return -1;
if (!mm_pkey_is_allocated(mm, pkey)) if (!mm_pkey_is_allocated(mm, pkey))
...@@ -132,7 +130,7 @@ extern int __arch_override_mprotect_pkey(struct vm_area_struct *vma, ...@@ -132,7 +130,7 @@ extern int __arch_override_mprotect_pkey(struct vm_area_struct *vma,
static inline int arch_override_mprotect_pkey(struct vm_area_struct *vma, static inline int arch_override_mprotect_pkey(struct vm_area_struct *vma,
int prot, int pkey) int prot, int pkey)
{ {
if (static_branch_likely(&pkey_disabled)) if (!mmu_has_feature(MMU_FTR_PKEY))
return 0; return 0;
/* /*
...@@ -150,7 +148,7 @@ extern int __arch_set_user_pkey_access(struct task_struct *tsk, int pkey, ...@@ -150,7 +148,7 @@ extern int __arch_set_user_pkey_access(struct task_struct *tsk, int pkey,
static inline int arch_set_user_pkey_access(struct task_struct *tsk, int pkey, static inline int arch_set_user_pkey_access(struct task_struct *tsk, int pkey,
unsigned long init_val) unsigned long init_val)
{ {
if (static_branch_likely(&pkey_disabled)) if (!mmu_has_feature(MMU_FTR_PKEY))
return -EINVAL; return -EINVAL;
/* /*
...@@ -167,7 +165,7 @@ static inline int arch_set_user_pkey_access(struct task_struct *tsk, int pkey, ...@@ -167,7 +165,7 @@ static inline int arch_set_user_pkey_access(struct task_struct *tsk, int pkey,
static inline bool arch_pkeys_enabled(void) static inline bool arch_pkeys_enabled(void)
{ {
return !static_branch_likely(&pkey_disabled); return mmu_has_feature(MMU_FTR_PKEY);
} }
extern void pkey_mm_init(struct mm_struct *mm); extern void pkey_mm_init(struct mm_struct *mm);
......
...@@ -12,8 +12,6 @@ ...@@ -12,8 +12,6 @@
#include <linux/pkeys.h> #include <linux/pkeys.h>
#include <linux/of_fdt.h> #include <linux/of_fdt.h>
DEFINE_STATIC_KEY_FALSE(pkey_disabled);
int num_pkey; /* Max number of pkeys supported */ int num_pkey; /* Max number of pkeys supported */
/* /*
* Keys marked in the reservation list cannot be allocated by userspace * Keys marked in the reservation list cannot be allocated by userspace
...@@ -126,7 +124,6 @@ void __init pkey_early_init_devtree(void) ...@@ -126,7 +124,6 @@ void __init pkey_early_init_devtree(void)
pkeys_total = scan_pkey_feature(); pkeys_total = scan_pkey_feature();
if (!pkeys_total) { if (!pkeys_total) {
/* No support for pkey. Mark it disabled */ /* No support for pkey. Mark it disabled */
static_branch_enable(&pkey_disabled);
return; return;
} }
...@@ -216,7 +213,7 @@ void __init pkey_early_init_devtree(void) ...@@ -216,7 +213,7 @@ void __init pkey_early_init_devtree(void)
void pkey_mm_init(struct mm_struct *mm) void pkey_mm_init(struct mm_struct *mm)
{ {
if (static_branch_likely(&pkey_disabled)) if (!mmu_has_feature(MMU_FTR_PKEY))
return; return;
mm_pkey_allocation_map(mm) = initial_allocation_mask; mm_pkey_allocation_map(mm) = initial_allocation_mask;
mm->context.execute_only_pkey = execute_only_key; mm->context.execute_only_pkey = execute_only_key;
...@@ -320,7 +317,7 @@ int __arch_set_user_pkey_access(struct task_struct *tsk, int pkey, ...@@ -320,7 +317,7 @@ int __arch_set_user_pkey_access(struct task_struct *tsk, int pkey,
void thread_pkey_regs_save(struct thread_struct *thread) void thread_pkey_regs_save(struct thread_struct *thread)
{ {
if (static_branch_likely(&pkey_disabled)) if (!mmu_has_feature(MMU_FTR_PKEY))
return; return;
/* /*
...@@ -334,7 +331,7 @@ void thread_pkey_regs_save(struct thread_struct *thread) ...@@ -334,7 +331,7 @@ void thread_pkey_regs_save(struct thread_struct *thread)
void thread_pkey_regs_restore(struct thread_struct *new_thread, void thread_pkey_regs_restore(struct thread_struct *new_thread,
struct thread_struct *old_thread) struct thread_struct *old_thread)
{ {
if (static_branch_likely(&pkey_disabled)) if (!mmu_has_feature(MMU_FTR_PKEY))
return; return;
if (old_thread->amr != new_thread->amr) if (old_thread->amr != new_thread->amr)
...@@ -347,7 +344,7 @@ void thread_pkey_regs_restore(struct thread_struct *new_thread, ...@@ -347,7 +344,7 @@ void thread_pkey_regs_restore(struct thread_struct *new_thread,
void thread_pkey_regs_init(struct thread_struct *thread) void thread_pkey_regs_init(struct thread_struct *thread)
{ {
if (static_branch_likely(&pkey_disabled)) if (!mmu_has_feature(MMU_FTR_PKEY))
return; return;
thread->amr = default_amr; thread->amr = default_amr;
...@@ -418,7 +415,7 @@ static bool pkey_access_permitted(int pkey, bool write, bool execute) ...@@ -418,7 +415,7 @@ static bool pkey_access_permitted(int pkey, bool write, bool execute)
bool arch_pte_access_permitted(u64 pte, bool write, bool execute) bool arch_pte_access_permitted(u64 pte, bool write, bool execute)
{ {
if (static_branch_likely(&pkey_disabled)) if (!mmu_has_feature(MMU_FTR_PKEY))
return true; return true;
return pkey_access_permitted(pte_to_pkey_bits(pte), write, execute); return pkey_access_permitted(pte_to_pkey_bits(pte), write, execute);
...@@ -435,7 +432,7 @@ bool arch_pte_access_permitted(u64 pte, bool write, bool execute) ...@@ -435,7 +432,7 @@ bool arch_pte_access_permitted(u64 pte, bool write, bool execute)
bool arch_vma_access_permitted(struct vm_area_struct *vma, bool write, bool arch_vma_access_permitted(struct vm_area_struct *vma, bool write,
bool execute, bool foreign) bool execute, bool foreign)
{ {
if (static_branch_likely(&pkey_disabled)) if (!mmu_has_feature(MMU_FTR_PKEY))
return true; return true;
/* /*
* Do not enforce our key-permissions on a foreign vma. * Do not enforce our key-permissions on a foreign vma.
...@@ -448,7 +445,7 @@ bool arch_vma_access_permitted(struct vm_area_struct *vma, bool write, ...@@ -448,7 +445,7 @@ bool arch_vma_access_permitted(struct vm_area_struct *vma, bool write,
void arch_dup_pkeys(struct mm_struct *oldmm, struct mm_struct *mm) void arch_dup_pkeys(struct mm_struct *oldmm, struct mm_struct *mm)
{ {
if (static_branch_likely(&pkey_disabled)) if (!mmu_has_feature(MMU_FTR_PKEY))
return; return;
/* Duplicate the oldmm pkey state in mm: */ /* Duplicate the oldmm pkey state in mm: */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment