2008-10-22 22:26:29 -07:00
# ifndef _ASM_X86_HUGETLB_H
# define _ASM_X86_HUGETLB_H
2008-04-28 02:13:27 -07:00
# include <asm/page.h>
2013-04-29 15:07:23 -07:00
# include <asm-generic/hugetlb.h>
2008-04-28 02:13:27 -07:00
2016-04-22 10:12:19 +02:00
# define hugepages_supported() boot_cpu_has(X86_FEATURE_PSE)
2008-04-28 02:13:27 -07:00
static inline int is_hugepage_only_range ( struct mm_struct * mm ,
unsigned long addr ,
unsigned long len ) {
return 0 ;
}
/*
* If the arch doesn ' t supply something else , assume that hugepage
* size aligned regions are ok without further preparation .
*/
2008-07-23 21:27:41 -07:00
static inline int prepare_hugepage_range ( struct file * file ,
unsigned long addr , unsigned long len )
2008-04-28 02:13:27 -07:00
{
2008-07-23 21:27:41 -07:00
struct hstate * h = hstate_file ( file ) ;
if ( len & ~ huge_page_mask ( h ) )
2008-04-28 02:13:27 -07:00
return - EINVAL ;
2008-07-23 21:27:41 -07:00
if ( addr & ~ huge_page_mask ( h ) )
2008-04-28 02:13:27 -07:00
return - EINVAL ;
return 0 ;
}
2008-07-23 21:27:10 -07:00
static inline void hugetlb_free_pgd_range ( struct mmu_gather * tlb ,
2008-04-28 02:13:27 -07:00
unsigned long addr , unsigned long end ,
unsigned long floor ,
unsigned long ceiling )
{
free_pgd_range ( tlb , addr , end , floor , ceiling ) ;
}
static inline void set_huge_pte_at ( struct mm_struct * mm , unsigned long addr ,
pte_t * ptep , pte_t pte )
{
set_pte_at ( mm , addr , ptep , pte ) ;
}
static inline pte_t huge_ptep_get_and_clear ( struct mm_struct * mm ,
unsigned long addr , pte_t * ptep )
{
return ptep_get_and_clear ( mm , addr , ptep ) ;
}
2008-04-28 02:13:28 -07:00
static inline void huge_ptep_clear_flush ( struct vm_area_struct * vma ,
unsigned long addr , pte_t * ptep )
{
2014-05-14 11:29:48 +02:00
ptep_clear_flush ( vma , addr , ptep ) ;
2008-04-28 02:13:28 -07:00
}
2008-04-28 02:13:29 -07:00
static inline int huge_pte_none ( pte_t pte )
{
return pte_none ( pte ) ;
}
static inline pte_t huge_pte_wrprotect ( pte_t pte )
{
return pte_wrprotect ( pte ) ;
}
static inline void huge_ptep_set_wrprotect ( struct mm_struct * mm ,
unsigned long addr , pte_t * ptep )
{
ptep_set_wrprotect ( mm , addr , ptep ) ;
}
static inline int huge_ptep_set_access_flags ( struct vm_area_struct * vma ,
unsigned long addr , pte_t * ptep ,
pte_t pte , int dirty )
{
return ptep_set_access_flags ( vma , addr , ptep , pte , dirty ) ;
}
static inline pte_t huge_ptep_get ( pte_t * ptep )
{
return * ptep ;
}
2012-10-08 16:29:32 -07:00
static inline void arch_clear_hugepage_flags ( struct page * page )
{
}
2017-07-06 15:39:17 -07:00
# ifdef CONFIG_ARCH_HAS_GIGANTIC_PAGE
static inline bool gigantic_page_supported ( void ) { return true ; }
# endif
2008-10-22 22:26:29 -07:00
# endif /* _ASM_X86_HUGETLB_H */