2005-04-16 15:20:36 -07:00
/*
* This file is subject to the terms and conditions of the GNU General Public
* License . See the file " COPYING " in the main directory of this archive
* for more details .
*
* Copyright ( C ) 1994 - 1999 , 2000 , 03 Ralf Baechle
* Copyright ( C ) 1999 , 2000 Silicon Graphics , Inc .
*/
# ifndef _ASM_PAGE_H
# define _ASM_PAGE_H
# ifdef __KERNEL__
# include <spaces.h>
/*
* PAGE_SHIFT determines the page size
*/
# ifdef CONFIG_PAGE_SIZE_4KB
# define PAGE_SHIFT 12
# endif
# ifdef CONFIG_PAGE_SIZE_8KB
# define PAGE_SHIFT 13
# endif
# ifdef CONFIG_PAGE_SIZE_16KB
# define PAGE_SHIFT 14
# endif
# ifdef CONFIG_PAGE_SIZE_64KB
# define PAGE_SHIFT 16
# endif
# define PAGE_SIZE (1UL << PAGE_SHIFT)
# define PAGE_MASK (~((1 << PAGE_SHIFT) - 1))
# ifndef __ASSEMBLY__
2007-01-10 09:44:05 +01:00
/*
* This gives the physical RAM offset .
*/
# ifndef PHYS_OFFSET
# define PHYS_OFFSET 0UL
# endif
/*
* It ' s normally defined only for FLATMEM config but it ' s
* used in our early mem init code for all memory models .
* So always define it .
*/
# define ARCH_PFN_OFFSET PFN_UP(PHYS_OFFSET)
2006-10-19 13:19:59 +02:00
# include <linux/pfn.h>
# include <asm/io.h>
2006-08-12 16:40:08 +01:00
2005-04-16 15:20:36 -07:00
extern void clear_page ( void * page ) ;
extern void copy_page ( void * to , void * from ) ;
extern unsigned long shm_align_mask ;
static inline unsigned long pages_do_alias ( unsigned long addr1 ,
unsigned long addr2 )
{
return ( addr1 ^ addr2 ) & shm_align_mask ;
}
struct page ;
static inline void clear_user_page ( void * addr , unsigned long vaddr ,
struct page * page )
{
extern void ( * flush_data_cache_page ) ( unsigned long addr ) ;
clear_page ( addr ) ;
2006-08-12 16:40:08 +01:00
if ( pages_do_alias ( ( unsigned long ) addr , vaddr & PAGE_MASK ) )
2005-04-16 15:20:36 -07:00
flush_data_cache_page ( ( unsigned long ) addr ) ;
}
2006-12-12 17:14:56 +00:00
extern void copy_user_page ( void * vto , void * vfrom , unsigned long vaddr ,
struct page * to ) ;
struct vm_area_struct ;
extern void copy_user_highpage ( struct page * to , struct page * from ,
unsigned long vaddr , struct vm_area_struct * vma ) ;
2005-04-16 15:20:36 -07:00
2006-12-12 17:14:56 +00:00
# define __HAVE_ARCH_COPY_USER_HIGHPAGE
2005-04-16 15:20:36 -07:00
/*
* These are used to make use of C type - checking . .
*/
# ifdef CONFIG_64BIT_PHYS_ADDR
2005-10-07 16:58:15 +01:00
# ifdef CONFIG_CPU_MIPS32
2005-04-16 15:20:36 -07:00
typedef struct { unsigned long pte_low , pte_high ; } pte_t ;
# define pte_val(x) ((x).pte_low | ((unsigned long long)(x).pte_high << 32))
2006-08-31 19:39:09 +01:00
# define __pte(x) ({ pte_t __pte = {(x), ((unsigned long long)(x)) >> 32}; __pte; })
2005-04-16 15:20:36 -07:00
# else
typedef struct { unsigned long long pte ; } pte_t ;
# define pte_val(x) ((x).pte)
2006-08-31 19:39:09 +01:00
# define __pte(x) ((pte_t) { (x) } )
2005-04-16 15:20:36 -07:00
# endif
# else
typedef struct { unsigned long pte ; } pte_t ;
# define pte_val(x) ((x).pte)
2005-02-10 12:19:59 +00:00
# define __pte(x) ((pte_t) { (x) } )
2006-08-31 19:39:09 +01:00
# endif
2005-04-16 15:20:36 -07:00
2005-02-10 12:19:59 +00:00
/*
* For 3 - level pagetables we defines these ourselves , for 2 - level the
* definitions are supplied by < asm - generic / pgtable - nopmd . h > .
*/
# ifdef CONFIG_64BIT
2005-04-16 15:20:36 -07:00
2005-02-10 12:19:59 +00:00
typedef struct { unsigned long pmd ; } pmd_t ;
2005-04-16 15:20:36 -07:00
# define pmd_val(x) ((x).pmd)
2005-02-10 12:19:59 +00:00
# define __pmd(x) ((pmd_t) { (x) } )
2005-04-16 15:20:36 -07:00
2005-02-10 12:19:59 +00:00
# endif
2005-04-16 15:20:36 -07:00
2005-02-10 12:19:59 +00:00
/*
* Right now we don ' t support 4 - level pagetables , so all pud - related
* definitions come from < asm - generic / pgtable - nopud . h > .
*/
/*
* Finall the top of the hierarchy , the pgd
*/
typedef struct { unsigned long pgd ; } pgd_t ;
# define pgd_val(x) ((x).pgd)
2005-04-16 15:20:36 -07:00
# define __pgd(x) ((pgd_t) { (x) } )
2005-02-10 12:19:59 +00:00
/*
* Manipulate page protection bits
*/
typedef struct { unsigned long pgprot ; } pgprot_t ;
# define pgprot_val(x) ((x).pgprot)
2005-04-16 15:20:36 -07:00
# define __pgprot(x) ((pgprot_t) { (x) } )
2005-02-10 12:19:59 +00:00
/*
* On R4000 - style MMUs where a TLB entry is mapping a adjacent even / odd
* pair of pages we only have a single global bit per pair of pages . When
* writing to the TLB make sure we always have the bit set for both pages
* or none . This macro is used to access the ` buddy ' of the pte we ' re just
* working on .
*/
# define ptep_buddy(x) ((pte_t *)((unsigned long)(x) ^ sizeof(pte_t)))
2005-04-16 15:20:36 -07:00
# endif /* !__ASSEMBLY__ */
/* to align the pointer to the (next) page boundary */
# define PAGE_ALIGN(addr) (((addr) + PAGE_SIZE - 1) & PAGE_MASK)
2007-01-10 09:44:05 +01:00
/*
* __pa ( ) / __va ( ) should be used only during mem init .
*/
2006-10-19 13:20:00 +02:00
# if defined(CONFIG_64BIT) && !defined(CONFIG_BUILD_ELF64)
# define __pa_page_offset(x) ((unsigned long)(x) < CKSEG0 ? PAGE_OFFSET : CKSEG0)
# else
# define __pa_page_offset(x) PAGE_OFFSET
# endif
2007-01-10 09:44:05 +01:00
# define __pa(x) ((unsigned long)(x) - __pa_page_offset(x) + PHYS_OFFSET)
# define __va(x) ((void *)((unsigned long)(x) + PAGE_OFFSET - PHYS_OFFSET))
# define __pa_symbol(x) __pa(RELOC_HIDE((unsigned long)(x),0))
2005-04-16 15:20:36 -07:00
# define pfn_to_kaddr(pfn) __va((pfn) << PAGE_SHIFT)
2006-06-12 09:13:56 +01:00
# ifdef CONFIG_FLATMEM
2007-01-10 09:44:05 +01:00
# define pfn_valid(pfn) ((pfn) >= ARCH_PFN_OFFSET && (pfn) < max_mapnr)
2006-06-12 09:13:56 +01:00
2006-07-05 01:22:44 +09:00
# elif defined(CONFIG_SPARSEMEM)
/* pfn_valid is defined in linux/mmzone.h */
2006-06-12 09:13:56 +01:00
# elif defined(CONFIG_NEED_MULTIPLE_NODES)
# define pfn_valid(pfn) \
( { \
unsigned long __pfn = ( pfn ) ; \
int __n = pfn_to_nid ( __pfn ) ; \
( ( __n > = 0 ) ? ( __pfn < NODE_DATA ( __n ) - > node_start_pfn + \
NODE_DATA ( __n ) - > node_spanned_pages ) \
: 0 ) ; \
} )
# endif
2006-10-19 13:19:59 +02:00
# define virt_to_page(kaddr) pfn_to_page(PFN_DOWN(virt_to_phys(kaddr)))
# define virt_addr_valid(kaddr) pfn_valid(PFN_DOWN(virt_to_phys(kaddr)))
2005-04-16 15:20:36 -07:00
# define VM_DATA_DEFAULT_FLAGS (VM_READ | VM_WRITE | VM_EXEC | \
VM_MAYREAD | VM_MAYWRITE | VM_MAYEXEC )
# define UNCAC_ADDR(addr) ((addr) - PAGE_OFFSET + UNCAC_BASE)
# define CAC_ADDR(addr) ((addr) - UNCAC_BASE + PAGE_OFFSET)
# ifdef CONFIG_LIMITED_DMA
# define WANT_PAGE_VIRTUAL
# endif
2006-03-27 01:15:43 -08:00
# include <asm-generic/memory_model.h>
2005-09-03 15:54:30 -07:00
# include <asm-generic/page.h>
2006-09-12 20:36:06 -07:00
# endif /* defined (__KERNEL__) */
2005-04-16 15:20:36 -07:00
# endif /* _ASM_PAGE_H */