pgtable-2level.h
上传用户:lgb322
上传日期:2013-02-24
资源大小:30529k
文件大小:2k
源码类别:

嵌入式Linux

开发平台:

Unix_Linux

  1. #ifndef _I386_PGTABLE_2LEVEL_H
  2. #define _I386_PGTABLE_2LEVEL_H
  3. /*
  4.  * traditional i386 two-level paging structure:
  5.  */
  6. #define PGDIR_SHIFT 22
  7. #define PTRS_PER_PGD 1024
  8. /*
  9.  * the i386 is two-level, so we don't really have any
  10.  * PMD directory physically.
  11.  */
  12. #define PMD_SHIFT 22
  13. #define PTRS_PER_PMD 1
  14. #define PTRS_PER_PTE 1024
  15. #define pte_ERROR(e) 
  16. printk("%s:%d: bad pte %08lx.n", __FILE__, __LINE__, (e).pte_low)
  17. #define pmd_ERROR(e) 
  18. printk("%s:%d: bad pmd %08lx.n", __FILE__, __LINE__, pmd_val(e))
  19. #define pgd_ERROR(e) 
  20. printk("%s:%d: bad pgd %08lx.n", __FILE__, __LINE__, pgd_val(e))
  21. /*
  22.  * The "pgd_xxx()" functions here are trivial for a folded two-level
  23.  * setup: the pgd is never bad, and a pmd always exists (as it's folded
  24.  * into the pgd entry)
  25.  */
  26. static inline int pgd_none(pgd_t pgd) { return 0; }
  27. static inline int pgd_bad(pgd_t pgd) { return 0; }
  28. static inline int pgd_present(pgd_t pgd) { return 1; }
  29. #define pgd_clear(xp) do { } while (0)
  30. /*
  31.  * Certain architectures need to do special things when PTEs
  32.  * within a page table are directly modified.  Thus, the following
  33.  * hook is made available.
  34.  */
  35. #define set_pte(pteptr, pteval) (*(pteptr) = pteval)
  36. /*
  37.  * (pmds are folded into pgds so this doesnt get actually called,
  38.  * but the define is needed for a generic inline function.)
  39.  */
  40. #define set_pmd(pmdptr, pmdval) (*(pmdptr) = pmdval)
  41. #define set_pgd(pgdptr, pgdval) (*(pgdptr) = pgdval)
  42. #define pgd_page(pgd) 
  43. ((unsigned long) __va(pgd_val(pgd) & PAGE_MASK))
  44. static inline pmd_t * pmd_offset(pgd_t * dir, unsigned long address)
  45. {
  46. return (pmd_t *) dir;
  47. }
  48. #define ptep_get_and_clear(xp) __pte(xchg(&(xp)->pte_low, 0))
  49. #define pte_same(a, b) ((a).pte_low == (b).pte_low)
  50. #define pte_page(x) (mem_map+((unsigned long)(((x).pte_low >> PAGE_SHIFT))))
  51. #define pte_none(x) (!(x).pte_low)
  52. #define __mk_pte(page_nr,pgprot) __pte(((page_nr) << PAGE_SHIFT) | pgprot_val(pgprot))
  53. #endif /* _I386_PGTABLE_2LEVEL_H */