2005-04-16 15:20:36 -07:00
# ifndef _ALPHA_PGALLOC_H
# define _ALPHA_PGALLOC_H
# include <linux/mm.h>
# include <linux/mmzone.h>
/*
* Allocate and free page tables . The xxx_kernel ( ) versions are
* used to allocate a kernel page table - this turns on ASN bits
* if any .
*/
static inline void
2008-02-08 04:22:04 -08:00
pmd_populate ( struct mm_struct * mm , pmd_t * pmd , pgtable_t pte )
2005-04-16 15:20:36 -07:00
{
pmd_set ( pmd , ( pte_t * ) ( page_to_pa ( pte ) + PAGE_OFFSET ) ) ;
}
2008-02-08 04:22:04 -08:00
# define pmd_pgtable(pmd) pmd_page(pmd)
2005-04-16 15:20:36 -07:00
static inline void
pmd_populate_kernel ( struct mm_struct * mm , pmd_t * pmd , pte_t * pte )
{
pmd_set ( pmd , pte ) ;
}
static inline void
pgd_populate ( struct mm_struct * mm , pgd_t * pgd , pmd_t * pmd )
{
pgd_set ( pgd , pmd ) ;
}
extern pgd_t * pgd_alloc ( struct mm_struct * mm ) ;
static inline void
2008-02-04 22:29:14 -08:00
pgd_free ( struct mm_struct * mm , pgd_t * pgd )
2005-04-16 15:20:36 -07:00
{
free_page ( ( unsigned long ) pgd ) ;
}
static inline pmd_t *
pmd_alloc_one ( struct mm_struct * mm , unsigned long address )
{
pmd_t * ret = ( pmd_t * ) __get_free_page ( GFP_KERNEL | __GFP_REPEAT | __GFP_ZERO ) ;
return ret ;
}
static inline void
2008-02-04 22:29:14 -08:00
pmd_free ( struct mm_struct * mm , pmd_t * pmd )
2005-04-16 15:20:36 -07:00
{
free_page ( ( unsigned long ) pmd ) ;
}
2009-01-15 13:51:20 -08:00
static inline pte_t *
pte_alloc_one_kernel ( struct mm_struct * mm , unsigned long address )
{
pte_t * pte = ( pte_t * ) __get_free_page ( GFP_KERNEL | __GFP_REPEAT | __GFP_ZERO ) ;
return pte ;
}
2005-04-16 15:20:36 -07:00
static inline void
2008-02-04 22:29:14 -08:00
pte_free_kernel ( struct mm_struct * mm , pte_t * pte )
2005-04-16 15:20:36 -07:00
{
free_page ( ( unsigned long ) pte ) ;
}
2008-02-08 04:22:04 -08:00
static inline pgtable_t
pte_alloc_one ( struct mm_struct * mm , unsigned long address )
2005-04-16 15:20:36 -07:00
{
2008-02-08 04:22:04 -08:00
pte_t * pte = pte_alloc_one_kernel ( mm , address ) ;
struct page * page ;
if ( ! pte )
return NULL ;
page = virt_to_page ( pte ) ;
pgtable_page_ctor ( page ) ;
return page ;
2005-04-16 15:20:36 -07:00
}
static inline void
2008-02-08 04:22:04 -08:00
pte_free ( struct mm_struct * mm , pgtable_t page )
2005-04-16 15:20:36 -07:00
{
2008-02-08 04:22:04 -08:00
pgtable_page_dtor ( page ) ;
2005-04-16 15:20:36 -07:00
__free_page ( page ) ;
}
# define check_pgt_cache() do { } while (0)
# endif /* _ALPHA_PGALLOC_H */