1 /* SPDX-License-Identifier: GPL-2.0 */
2 #ifndef _ASM_PARISC64_HUGETLB_H
3 #define _ASM_PARISC64_HUGETLB_H
4 
5 #include <asm/page.h>
6 
7 #define __HAVE_ARCH_HUGE_SET_HUGE_PTE_AT
8 void set_huge_pte_at(struct mm_struct *mm, unsigned long addr,
9 		     pte_t *ptep, pte_t pte, unsigned long sz);
10 
11 #define __HAVE_ARCH_HUGE_PTEP_GET_AND_CLEAR
12 pte_t huge_ptep_get_and_clear(struct mm_struct *mm, unsigned long addr,
13 			      pte_t *ptep);
14 
15 /*
16  * If the arch doesn't supply something else, assume that hugepage
17  * size aligned regions are ok without further preparation.
18  */
19 #define __HAVE_ARCH_PREPARE_HUGEPAGE_RANGE
prepare_hugepage_range(struct file * file,unsigned long addr,unsigned long len)20 static inline int prepare_hugepage_range(struct file *file,
21 			unsigned long addr, unsigned long len)
22 {
23 	if (len & ~HPAGE_MASK)
24 		return -EINVAL;
25 	if (addr & ~HPAGE_MASK)
26 		return -EINVAL;
27 	return 0;
28 }
29 
30 #define __HAVE_ARCH_HUGE_PTEP_CLEAR_FLUSH
huge_ptep_clear_flush(struct vm_area_struct * vma,unsigned long addr,pte_t * ptep)31 static inline pte_t huge_ptep_clear_flush(struct vm_area_struct *vma,
32 					  unsigned long addr, pte_t *ptep)
33 {
34 	return *ptep;
35 }
36 
37 #define __HAVE_ARCH_HUGE_PTEP_SET_WRPROTECT
38 void huge_ptep_set_wrprotect(struct mm_struct *mm,
39 					   unsigned long addr, pte_t *ptep);
40 
41 #define __HAVE_ARCH_HUGE_PTEP_SET_ACCESS_FLAGS
42 int huge_ptep_set_access_flags(struct vm_area_struct *vma,
43 					     unsigned long addr, pte_t *ptep,
44 					     pte_t pte, int dirty);
45 
46 #include <asm-generic/hugetlb.h>
47 
48 #endif /* _ASM_PARISC64_HUGETLB_H */
49