xref: /linux/arch/alpha/include/asm/page.h (revision 6aacab308a5dfd222b2d23662bbae60c11007cfb)
1 /* SPDX-License-Identifier: GPL-2.0 */
2 #ifndef _ALPHA_PAGE_H
3 #define _ALPHA_PAGE_H
4 
5 #include <linux/const.h>
6 #include <asm/pal.h>
7 #include <vdso/page.h>
8 
9 #ifndef __ASSEMBLER__
10 
11 #define STRICT_MM_TYPECHECKS
12 
13 extern void clear_page(void *page);
14 
15 #define vma_alloc_zeroed_movable_folio(vma, vaddr) \
16 	vma_alloc_folio(GFP_HIGHUSER_MOVABLE | __GFP_ZERO, 0, vma, vaddr)
17 
18 extern void copy_page(void * _to, void * _from);
19 #define copy_user_page(to, from, vaddr, pg)	copy_page(to, from)
20 
21 #ifdef STRICT_MM_TYPECHECKS
22 /*
23  * These are used to make use of C type-checking..
24  */
25 typedef struct { unsigned long pte; } pte_t;
26 typedef struct { unsigned long pmd; } pmd_t;
27 typedef struct { unsigned long pgd; } pgd_t;
28 typedef struct { unsigned long pgprot; } pgprot_t;
29 
30 #define pte_val(x)	((x).pte)
31 #define pmd_val(x)	((x).pmd)
32 #define pgd_val(x)	((x).pgd)
33 #define pgprot_val(x)	((x).pgprot)
34 
35 #define __pte(x)	((pte_t) { (x) } )
36 #define __pmd(x)	((pmd_t) { (x) } )
37 #define __pgd(x)	((pgd_t) { (x) } )
38 #define __pgprot(x)	((pgprot_t) { (x) } )
39 
40 #else
41 /*
42  * .. while these make it easier on the compiler
43  */
44 typedef unsigned long pte_t;
45 typedef unsigned long pmd_t;
46 typedef unsigned long pgd_t;
47 typedef unsigned long pgprot_t;
48 
49 #define pte_val(x)	(x)
50 #define pmd_val(x)	(x)
51 #define pgd_val(x)	(x)
52 #define pgprot_val(x)	(x)
53 
54 #define __pte(x)	(x)
55 #define __pgd(x)	(x)
56 #define __pgprot(x)	(x)
57 
58 #endif /* STRICT_MM_TYPECHECKS */
59 
60 typedef struct page *pgtable_t;
61 
62 #ifdef USE_48_BIT_KSEG
63 #define PAGE_OFFSET		0xffff800000000000UL
64 #else
65 #define PAGE_OFFSET		0xfffffc0000000000UL
66 #endif
67 
68 #else
69 
70 #ifdef USE_48_BIT_KSEG
71 #define PAGE_OFFSET		0xffff800000000000
72 #else
73 #define PAGE_OFFSET		0xfffffc0000000000
74 #endif
75 
76 #endif /* !__ASSEMBLER__ */
77 
78 #define __pa(x)			((unsigned long) (x) - PAGE_OFFSET)
79 #define __va(x)			((void *)((unsigned long) (x) + PAGE_OFFSET))
80 
81 #define virt_to_page(kaddr)	pfn_to_page(__pa(kaddr) >> PAGE_SHIFT)
82 #define virt_addr_valid(kaddr)	pfn_valid((__pa(kaddr) >> PAGE_SHIFT))
83 
84 #include <asm-generic/memory_model.h>
85 #include <asm-generic/getorder.h>
86 
87 #endif /* _ALPHA_PAGE_H */
88