/* SPDX-License-Identifier: GPL-2.0 */ #ifndef _ASM_POWERPC_NOHASH_HUGETLB_E500_H #define _ASM_POWERPC_NOHASH_HUGETLB_E500_H void flush_hugetlb_page(struct vm_area_struct *vma, unsigned long vmaddr); static inline int check_and_get_huge_psize(int shift) { if (shift & 1) /* Not a power of 4 */ return -EINVAL; return shift_to_mmu_psize(shift); } static inline pte_t arch_make_huge_pte(pte_t entry, unsigned int shift, vm_flags_t flags) { unsigned int tsize = shift - _PAGE_PSIZE_SHIFT_OFFSET; pte_basic_t val = (tsize << _PAGE_PSIZE_SHIFT) & _PAGE_PSIZE_MSK; return __pte((pte_val(entry) & ~(pte_basic_t)_PAGE_PSIZE_MSK) | val); } #define arch_make_huge_pte arch_make_huge_pte #endif /* _ASM_POWERPC_NOHASH_HUGETLB_E500_H */