Path: blob/master/arch/powerpc/include/asm/book3s/64/hash-pkey.h
26519 views
/* SPDX-License-Identifier: GPL-2.0 */1#ifndef _ASM_POWERPC_BOOK3S_64_HASH_PKEY_H2#define _ASM_POWERPC_BOOK3S_64_HASH_PKEY_H34/* We use key 3 for KERNEL */5#define HASH_DEFAULT_KERNEL_KEY (HPTE_R_KEY_BIT0 | HPTE_R_KEY_BIT1)67static inline u64 hash__vmflag_to_pte_pkey_bits(u64 vm_flags)8{9return (((vm_flags & VM_PKEY_BIT0) ? H_PTE_PKEY_BIT0 : 0x0UL) |10((vm_flags & VM_PKEY_BIT1) ? H_PTE_PKEY_BIT1 : 0x0UL) |11((vm_flags & VM_PKEY_BIT2) ? H_PTE_PKEY_BIT2 : 0x0UL) |12((vm_flags & VM_PKEY_BIT3) ? H_PTE_PKEY_BIT3 : 0x0UL) |13((vm_flags & VM_PKEY_BIT4) ? H_PTE_PKEY_BIT4 : 0x0UL));14}1516static inline u64 pte_to_hpte_pkey_bits(u64 pteflags, unsigned long flags)17{18unsigned long pte_pkey;1920pte_pkey = (((pteflags & H_PTE_PKEY_BIT4) ? HPTE_R_KEY_BIT4 : 0x0UL) |21((pteflags & H_PTE_PKEY_BIT3) ? HPTE_R_KEY_BIT3 : 0x0UL) |22((pteflags & H_PTE_PKEY_BIT2) ? HPTE_R_KEY_BIT2 : 0x0UL) |23((pteflags & H_PTE_PKEY_BIT1) ? HPTE_R_KEY_BIT1 : 0x0UL) |24((pteflags & H_PTE_PKEY_BIT0) ? HPTE_R_KEY_BIT0 : 0x0UL));2526if (mmu_has_feature(MMU_FTR_KUAP) ||27mmu_has_feature(MMU_FTR_BOOK3S_KUEP)) {28if ((pte_pkey == 0) && (flags & HPTE_USE_KERNEL_KEY))29return HASH_DEFAULT_KERNEL_KEY;30}3132return pte_pkey;33}3435static inline u16 hash__pte_to_pkey_bits(u64 pteflags)36{37return (((pteflags & H_PTE_PKEY_BIT4) ? 0x10 : 0x0UL) |38((pteflags & H_PTE_PKEY_BIT3) ? 0x8 : 0x0UL) |39((pteflags & H_PTE_PKEY_BIT2) ? 0x4 : 0x0UL) |40((pteflags & H_PTE_PKEY_BIT1) ? 0x2 : 0x0UL) |41((pteflags & H_PTE_PKEY_BIT0) ? 0x1 : 0x0UL));42}4344#endif454647