page.h 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. #ifndef _PARISC_PAGE_H
  3. #define _PARISC_PAGE_H
  4. #include <linux/const.h>
  5. #include <vdso/page.h>
  6. #define HAVE_ARCH_HUGETLB_UNMAPPED_AREA
  7. #ifndef __ASSEMBLER__
  8. #include <asm/types.h>
  9. #include <asm/cache.h>
  10. #define clear_page(page) clear_page_asm((void *)(page))
  11. #define copy_page(to, from) copy_page_asm((void *)(to), (void *)(from))
  12. struct page;
  13. struct vm_area_struct;
  14. void clear_page_asm(void *page);
  15. void copy_page_asm(void *to, void *from);
  16. void copy_user_highpage(struct page *to, struct page *from, unsigned long vaddr,
  17. struct vm_area_struct *vma);
  18. #define __HAVE_ARCH_COPY_USER_HIGHPAGE
  19. /*
  20. * These are used to make use of C type-checking..
  21. */
  22. #define STRICT_MM_TYPECHECKS
  23. #ifdef STRICT_MM_TYPECHECKS
  24. typedef struct { unsigned long pte; } pte_t; /* either 32 or 64bit */
  25. /* NOTE: even on 64 bits, these entries are __u32 because we allocate
  26. * the pmd and pgd in ZONE_DMA (i.e. under 4GB) */
  27. typedef struct { __u32 pgd; } pgd_t;
  28. typedef struct { unsigned long pgprot; } pgprot_t;
  29. #if CONFIG_PGTABLE_LEVELS == 3
  30. typedef struct { __u32 pmd; } pmd_t;
  31. #define __pmd(x) ((pmd_t) { (x) } )
  32. /* pXd_val() do not work as lvalues, so make sure we don't use them as such. */
  33. #define pmd_val(x) ((x).pmd + 0)
  34. #endif
  35. #define pte_val(x) ((x).pte)
  36. #define pgd_val(x) ((x).pgd + 0)
  37. #define pgprot_val(x) ((x).pgprot)
  38. #define __pte(x) ((pte_t) { (x) } )
  39. #define __pgd(x) ((pgd_t) { (x) } )
  40. #define __pgprot(x) ((pgprot_t) { (x) } )
  41. #else
  42. /*
  43. * .. while these make it easier on the compiler
  44. */
  45. typedef unsigned long pte_t;
  46. #if CONFIG_PGTABLE_LEVELS == 3
  47. typedef __u32 pmd_t;
  48. #define pmd_val(x) (x)
  49. #define __pmd(x) (x)
  50. #endif
  51. typedef __u32 pgd_t;
  52. typedef unsigned long pgprot_t;
  53. #define pte_val(x) (x)
  54. #define pgd_val(x) (x)
  55. #define pgprot_val(x) (x)
  56. #define __pte(x) (x)
  57. #define __pgd(x) (x)
  58. #define __pgprot(x) (x)
  59. #endif /* STRICT_MM_TYPECHECKS */
  60. #define set_pmd(pmdptr, pmdval) (*(pmdptr) = (pmdval))
  61. #if CONFIG_PGTABLE_LEVELS == 3
  62. #define set_pud(pudptr, pudval) (*(pudptr) = (pudval))
  63. #endif
  64. typedef struct page *pgtable_t;
  65. typedef struct __physmem_range {
  66. unsigned long start_pfn;
  67. unsigned long pages; /* PAGE_SIZE pages */
  68. } physmem_range_t;
  69. extern physmem_range_t pmem_ranges[];
  70. extern int npmem_ranges;
  71. #endif /* !__ASSEMBLER__ */
  72. /* WARNING: The definitions below must match exactly to sizeof(pte_t)
  73. * etc
  74. */
  75. #ifdef CONFIG_64BIT
  76. #define BITS_PER_PTE_ENTRY 3
  77. #define BITS_PER_PMD_ENTRY 2
  78. #define BITS_PER_PGD_ENTRY 2
  79. #else
  80. #define BITS_PER_PTE_ENTRY 2
  81. #define BITS_PER_PMD_ENTRY 2
  82. #define BITS_PER_PGD_ENTRY 2
  83. #endif
  84. #define PGD_ENTRY_SIZE (1UL << BITS_PER_PGD_ENTRY)
  85. #define PMD_ENTRY_SIZE (1UL << BITS_PER_PMD_ENTRY)
  86. #define PTE_ENTRY_SIZE (1UL << BITS_PER_PTE_ENTRY)
  87. #define LINUX_GATEWAY_SPACE 0
  88. /* This governs the relationship between virtual and physical addresses.
  89. * If you alter it, make sure to take care of our various fixed mapping
  90. * segments in fixmap.h */
  91. #ifdef CONFIG_64BIT
  92. #define __PAGE_OFFSET_DEFAULT (0x40000000) /* 1GB */
  93. #else
  94. #define __PAGE_OFFSET_DEFAULT (0x10000000) /* 256MB */
  95. #endif
  96. #if defined(BOOTLOADER)
  97. #define __PAGE_OFFSET (0) /* bootloader uses physical addresses */
  98. #else
  99. #define __PAGE_OFFSET __PAGE_OFFSET_DEFAULT
  100. #endif /* BOOTLOADER */
  101. #define PAGE_OFFSET ((unsigned long)__PAGE_OFFSET)
  102. /* The size of the gateway page (we leave lots of room for expansion) */
  103. #define GATEWAY_PAGE_SIZE 0x4000
  104. /* The start of the actual kernel binary---used in vmlinux.lds.S
  105. * Leave some space after __PAGE_OFFSET for detecting kernel null
  106. * ptr derefs */
  107. #define KERNEL_BINARY_TEXT_START (__PAGE_OFFSET + 0x100000)
  108. /* These macros don't work for 64-bit C code -- don't allow in C at all */
  109. #ifdef __ASSEMBLER__
  110. # define PA(x) ((x)-__PAGE_OFFSET)
  111. # define VA(x) ((x)+__PAGE_OFFSET)
  112. #endif
  113. #define __pa(x) ((unsigned long)(x)-PAGE_OFFSET)
  114. #define __va(x) ((void *)((unsigned long)(x)+PAGE_OFFSET))
  115. #ifdef CONFIG_HUGETLB_PAGE
  116. #define HPAGE_SHIFT PMD_SHIFT /* fixed for transparent huge pages */
  117. #define HPAGE_SIZE ((1UL) << HPAGE_SHIFT)
  118. #define HPAGE_MASK (~(HPAGE_SIZE - 1))
  119. #define HUGETLB_PAGE_ORDER (HPAGE_SHIFT - PAGE_SHIFT)
  120. #if defined(CONFIG_64BIT) && defined(CONFIG_PARISC_PAGE_SIZE_4KB)
  121. # define REAL_HPAGE_SHIFT 20 /* 20 = 1MB */
  122. # define _HUGE_PAGE_SIZE_ENCODING_DEFAULT _PAGE_SIZE_ENCODING_1M
  123. #elif !defined(CONFIG_64BIT) && defined(CONFIG_PARISC_PAGE_SIZE_4KB)
  124. # define REAL_HPAGE_SHIFT 22 /* 22 = 4MB */
  125. # define _HUGE_PAGE_SIZE_ENCODING_DEFAULT _PAGE_SIZE_ENCODING_4M
  126. #else
  127. # define REAL_HPAGE_SHIFT 24 /* 24 = 16MB */
  128. # define _HUGE_PAGE_SIZE_ENCODING_DEFAULT _PAGE_SIZE_ENCODING_16M
  129. #endif
  130. #endif /* CONFIG_HUGETLB_PAGE */
  131. #define virt_addr_valid(kaddr) pfn_valid(__pa(kaddr) >> PAGE_SHIFT)
  132. #define virt_to_page(kaddr) pfn_to_page(__pa(kaddr) >> PAGE_SHIFT)
  133. #include <asm-generic/memory_model.h>
  134. #include <asm-generic/getorder.h>
  135. #include <asm/pdc.h>
  136. #define PAGE0 ((struct zeropage *)absolute_pointer(__PAGE_OFFSET))
  137. /* DEFINITION OF THE ZERO-PAGE (PAG0) */
  138. /* based on work by Jason Eckhardt (jason@equator.com) */
  139. #endif /* _PARISC_PAGE_H */