0001
0002 #ifndef _ASM_POWERPC_BOOK3S_64_HASH_PKEY_H
0003 #define _ASM_POWERPC_BOOK3S_64_HASH_PKEY_H
0004
0005
0006 #define HASH_DEFAULT_KERNEL_KEY (HPTE_R_KEY_BIT0 | HPTE_R_KEY_BIT1)
0007
0008 static inline u64 hash__vmflag_to_pte_pkey_bits(u64 vm_flags)
0009 {
0010 return (((vm_flags & VM_PKEY_BIT0) ? H_PTE_PKEY_BIT0 : 0x0UL) |
0011 ((vm_flags & VM_PKEY_BIT1) ? H_PTE_PKEY_BIT1 : 0x0UL) |
0012 ((vm_flags & VM_PKEY_BIT2) ? H_PTE_PKEY_BIT2 : 0x0UL) |
0013 ((vm_flags & VM_PKEY_BIT3) ? H_PTE_PKEY_BIT3 : 0x0UL) |
0014 ((vm_flags & VM_PKEY_BIT4) ? H_PTE_PKEY_BIT4 : 0x0UL));
0015 }
0016
0017 static inline u64 pte_to_hpte_pkey_bits(u64 pteflags, unsigned long flags)
0018 {
0019 unsigned long pte_pkey;
0020
0021 pte_pkey = (((pteflags & H_PTE_PKEY_BIT4) ? HPTE_R_KEY_BIT4 : 0x0UL) |
0022 ((pteflags & H_PTE_PKEY_BIT3) ? HPTE_R_KEY_BIT3 : 0x0UL) |
0023 ((pteflags & H_PTE_PKEY_BIT2) ? HPTE_R_KEY_BIT2 : 0x0UL) |
0024 ((pteflags & H_PTE_PKEY_BIT1) ? HPTE_R_KEY_BIT1 : 0x0UL) |
0025 ((pteflags & H_PTE_PKEY_BIT0) ? HPTE_R_KEY_BIT0 : 0x0UL));
0026
0027 if (mmu_has_feature(MMU_FTR_BOOK3S_KUAP) ||
0028 mmu_has_feature(MMU_FTR_BOOK3S_KUEP)) {
0029 if ((pte_pkey == 0) && (flags & HPTE_USE_KERNEL_KEY))
0030 return HASH_DEFAULT_KERNEL_KEY;
0031 }
0032
0033 return pte_pkey;
0034 }
0035
0036 static inline u16 hash__pte_to_pkey_bits(u64 pteflags)
0037 {
0038 return (((pteflags & H_PTE_PKEY_BIT4) ? 0x10 : 0x0UL) |
0039 ((pteflags & H_PTE_PKEY_BIT3) ? 0x8 : 0x0UL) |
0040 ((pteflags & H_PTE_PKEY_BIT2) ? 0x4 : 0x0UL) |
0041 ((pteflags & H_PTE_PKEY_BIT1) ? 0x2 : 0x0UL) |
0042 ((pteflags & H_PTE_PKEY_BIT0) ? 0x1 : 0x0UL));
0043 }
0044
0045 #endif