linux-bk/include/asm-arm/page.h
<<
>>
Prefs
   1/*
   2 *  linux/include/asm-arm/page.h
   3 *
   4 *  Copyright (C) 1995-2003 Russell King
   5 *
   6 * This program is free software; you can redistribute it and/or modify
   7 * it under the terms of the GNU General Public License version 2 as
   8 * published by the Free Software Foundation.
   9 */
  10#ifndef _ASMARM_PAGE_H
  11#define _ASMARM_PAGE_H
  12
  13#include <linux/config.h>
  14
  15/* PAGE_SHIFT determines the page size */
  16#define PAGE_SHIFT              12
  17#define PAGE_SIZE               (1UL << PAGE_SHIFT)
  18#define PAGE_MASK               (~(PAGE_SIZE-1))
  19
  20#ifdef __KERNEL__
  21
  22/* to align the pointer to the (next) page boundary */
  23#define PAGE_ALIGN(addr)        (((addr)+PAGE_SIZE-1)&PAGE_MASK)
  24
  25#ifndef __ASSEMBLY__
  26
  27#include <asm/glue.h>
  28
  29/*
  30 *      User Space Model
  31 *      ================
  32 *
  33 *      This section selects the correct set of functions for dealing with
  34 *      page-based copying and clearing for user space for the particular
  35 *      processor(s) we're building for.
  36 *
  37 *      We have the following to choose from:
  38 *        v3            - ARMv3
  39 *        v4wt          - ARMv4 with writethrough cache, without minicache
  40 *        v4wb          - ARMv4 with writeback cache, without minicache
  41 *        v4_mc         - ARMv4 with minicache
  42 *        xscale        - Xscale
  43 */
  44#undef _USER
  45#undef MULTI_USER
  46
  47#ifdef CONFIG_CPU_COPY_V3
  48# ifdef _USER
  49#  define MULTI_USER 1
  50# else
  51#  define _USER v3
  52# endif
  53#endif
  54
  55#ifdef CONFIG_CPU_COPY_V4WT
  56# ifdef _USER
  57#  define MULTI_USER 1
  58# else
  59#  define _USER v4wt
  60# endif
  61#endif
  62
  63#ifdef CONFIG_CPU_COPY_V4WB
  64# ifdef _USER
  65#  define MULTI_USER 1
  66# else
  67#  define _USER v4wb
  68# endif
  69#endif
  70
  71#ifdef CONFIG_CPU_SA1100
  72# ifdef _USER
  73#  define MULTI_USER 1
  74# else
  75#  define _USER v4_mc
  76# endif
  77#endif
  78
  79#ifdef CONFIG_CPU_XSCALE
  80# ifdef _USER
  81#  define MULTI_USER 1
  82# else
  83#  define _USER xscale_mc
  84# endif
  85#endif
  86
  87#ifdef CONFIG_CPU_COPY_V6
  88# ifdef _USER
  89#  define MULTI_USER 1
  90# else
  91#  define _USER v6
  92# endif
  93#endif
  94
  95#ifndef _USER
  96#error Unknown user operations model
  97#endif
  98
  99struct cpu_user_fns {
 100        void (*cpu_clear_user_page)(void *p, unsigned long user);
 101        void (*cpu_copy_user_page)(void *to, const void *from,
 102                                   unsigned long user);
 103};
 104
 105#ifdef MULTI_USER
 106extern struct cpu_user_fns cpu_user;
 107
 108#define __cpu_clear_user_page   cpu_user.cpu_clear_user_page
 109#define __cpu_copy_user_page    cpu_user.cpu_copy_user_page
 110
 111#else
 112
 113#define __cpu_clear_user_page   __glue(_USER,_clear_user_page)
 114#define __cpu_copy_user_page    __glue(_USER,_copy_user_page)
 115
 116extern void __cpu_clear_user_page(void *p, unsigned long user);
 117extern void __cpu_copy_user_page(void *to, const void *from,
 118                                 unsigned long user);
 119#endif
 120
 121#define clear_user_page(addr,vaddr,pg)                  \
 122        do {                                            \
 123                preempt_disable();                      \
 124                __cpu_clear_user_page(addr, vaddr);     \
 125                preempt_enable();                       \
 126        } while (0)
 127
 128#define copy_user_page(to,from,vaddr,pg)                \
 129        do {                                            \
 130                preempt_disable();                      \
 131                __cpu_copy_user_page(to, from, vaddr);  \
 132                preempt_enable();                       \
 133        } while (0)
 134
 135#define clear_page(page)        memzero((void *)(page), PAGE_SIZE)
 136extern void copy_page(void *to, void *from);
 137
 138#undef STRICT_MM_TYPECHECKS
 139
 140#ifdef STRICT_MM_TYPECHECKS
 141/*
 142 * These are used to make use of C type-checking..
 143 */
 144typedef struct { unsigned long pte; } pte_t;
 145typedef struct { unsigned long pmd; } pmd_t;
 146typedef struct { unsigned long pgd[2]; } pgd_t;
 147typedef struct { unsigned long pgprot; } pgprot_t;
 148
 149#define pte_val(x)      ((x).pte)
 150#define pmd_val(x)      ((x).pmd)
 151#define pgd_val(x)      ((x).pgd[0])
 152#define pgprot_val(x)   ((x).pgprot)
 153
 154#define __pte(x)        ((pte_t) { (x) } )
 155#define __pmd(x)        ((pmd_t) { (x) } )
 156#define __pgprot(x)     ((pgprot_t) { (x) } )
 157
 158#else
 159/*
 160 * .. while these make it easier on the compiler
 161 */
 162typedef unsigned long pte_t;
 163typedef unsigned long pmd_t;
 164typedef unsigned long pgd_t[2];
 165typedef unsigned long pgprot_t;
 166
 167#define pte_val(x)      (x)
 168#define pmd_val(x)      (x)
 169#define pgd_val(x)      ((x)[0])
 170#define pgprot_val(x)   (x)
 171
 172#define __pte(x)        (x)
 173#define __pmd(x)        (x)
 174#define __pgprot(x)     (x)
 175
 176#endif /* STRICT_MM_TYPECHECKS */
 177
 178/* Pure 2^n version of get_order */
 179static inline int get_order(unsigned long size)
 180{
 181        int order;
 182
 183        size = (size-1) >> (PAGE_SHIFT-1);
 184        order = -1;
 185        do {
 186                size >>= 1;
 187                order++;
 188        } while (size);
 189        return order;
 190}
 191
 192#include <asm/memory.h>
 193
 194#endif /* !__ASSEMBLY__ */
 195
 196#define VM_DATA_DEFAULT_FLAGS   (VM_READ | VM_WRITE | VM_EXEC | \
 197                                 VM_MAYREAD | VM_MAYWRITE | VM_MAYEXEC)
 198
 199#endif /* __KERNEL__ */
 200
 201#endif
 202
lxr.linux.no kindly hosted by Redpill Linpro AS, provider of Linux consulting and operations services since 1995.