|
|
@@ -217,12 +217,6 @@ static inline void enter_lazy_tlb(struct mm_struct *mm,
|
|
|
#endif
|
|
|
}
|
|
|
|
|
|
-static inline int arch_dup_mmap(struct mm_struct *oldmm,
|
|
|
- struct mm_struct *mm)
|
|
|
-{
|
|
|
- return 0;
|
|
|
-}
|
|
|
-
|
|
|
#ifndef CONFIG_PPC_BOOK3S_64
|
|
|
static inline void arch_exit_mmap(struct mm_struct *mm)
|
|
|
{
|
|
|
@@ -247,6 +241,7 @@ static inline void arch_bprm_mm_init(struct mm_struct *mm,
|
|
|
#ifdef CONFIG_PPC_MEM_KEYS
|
|
|
bool arch_vma_access_permitted(struct vm_area_struct *vma, bool write,
|
|
|
bool execute, bool foreign);
|
|
|
+void arch_dup_pkeys(struct mm_struct *oldmm, struct mm_struct *mm);
|
|
|
#else /* CONFIG_PPC_MEM_KEYS */
|
|
|
static inline bool arch_vma_access_permitted(struct vm_area_struct *vma,
|
|
|
bool write, bool execute, bool foreign)
|
|
|
@@ -259,6 +254,7 @@ static inline bool arch_vma_access_permitted(struct vm_area_struct *vma,
|
|
|
#define thread_pkey_regs_save(thread)
|
|
|
#define thread_pkey_regs_restore(new_thread, old_thread)
|
|
|
#define thread_pkey_regs_init(thread)
|
|
|
+#define arch_dup_pkeys(oldmm, mm)
|
|
|
|
|
|
static inline u64 pte_to_hpte_pkey_bits(u64 pteflags)
|
|
|
{
|
|
|
@@ -267,5 +263,12 @@ static inline u64 pte_to_hpte_pkey_bits(u64 pteflags)
|
|
|
|
|
|
#endif /* CONFIG_PPC_MEM_KEYS */
|
|
|
|
|
|
+static inline int arch_dup_mmap(struct mm_struct *oldmm,
|
|
|
+ struct mm_struct *mm)
|
|
|
+{
|
|
|
+ arch_dup_pkeys(oldmm, mm);
|
|
|
+ return 0;
|
|
|
+}
|
|
|
+
|
|
|
#endif /* __KERNEL__ */
|
|
|
#endif /* __ASM_POWERPC_MMU_CONTEXT_H */
|