hc
2024-03-22 a0752693d998599af469473b8dc239ef973a012f
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef __ASM_MEMORY_MODEL_H
#define __ASM_MEMORY_MODEL_H
 
#include <linux/pfn.h>
 
#ifndef __ASSEMBLY__
 
#if defined(CONFIG_FLATMEM)
 
#ifndef ARCH_PFN_OFFSET
#define ARCH_PFN_OFFSET        (0UL)
#endif
 
#elif defined(CONFIG_DISCONTIGMEM)
 
#ifndef arch_pfn_to_nid
#define arch_pfn_to_nid(pfn)    pfn_to_nid(pfn)
#endif
 
#ifndef arch_local_page_offset
#define arch_local_page_offset(pfn, nid)    \
   ((pfn) - NODE_DATA(nid)->node_start_pfn)
#endif
 
#endif /* CONFIG_DISCONTIGMEM */
 
/*
 * supports 3 memory models.
 */
#if defined(CONFIG_FLATMEM)
 
#define __pfn_to_page(pfn)    (mem_map + ((pfn) - ARCH_PFN_OFFSET))
#define __page_to_pfn(page)    ((unsigned long)((page) - mem_map) + \
                ARCH_PFN_OFFSET)
#elif defined(CONFIG_DISCONTIGMEM)
 
#define __pfn_to_page(pfn)            \
({    unsigned long __pfn = (pfn);        \
   unsigned long __nid = arch_pfn_to_nid(__pfn);  \
   NODE_DATA(__nid)->node_mem_map + arch_local_page_offset(__pfn, __nid);\
})
 
#define __page_to_pfn(pg)                        \
({    const struct page *__pg = (pg);                    \
   struct pglist_data *__pgdat = NODE_DATA(page_to_nid(__pg));    \
   (unsigned long)(__pg - __pgdat->node_mem_map) +            \
    __pgdat->node_start_pfn;                    \
})
 
#elif defined(CONFIG_SPARSEMEM_VMEMMAP)
 
/* memmap is virtually contiguous.  */
#define __pfn_to_page(pfn)    (vmemmap + (pfn))
#define __page_to_pfn(page)    (unsigned long)((page) - vmemmap)
 
#elif defined(CONFIG_SPARSEMEM)
/*
 * Note: section's mem_map is encoded to reflect its start_pfn.
 * section[i].section_mem_map == mem_map's address - start_pfn;
 */
#define __page_to_pfn(pg)                    \
({    const struct page *__pg = (pg);                \
   int __sec = page_to_section(__pg);            \
   (unsigned long)(__pg - __section_mem_map_addr(__nr_to_section(__sec)));    \
})
 
#define __pfn_to_page(pfn)                \
({    unsigned long __pfn = (pfn);            \
   struct mem_section *__sec = __pfn_to_section(__pfn);    \
   __section_mem_map_addr(__sec) + __pfn;        \
})
#endif /* CONFIG_FLATMEM/DISCONTIGMEM/SPARSEMEM */
 
/*
 * Convert a physical address to a Page Frame Number and back
 */
#define    __phys_to_pfn(paddr)    PHYS_PFN(paddr)
#define    __pfn_to_phys(pfn)    PFN_PHYS(pfn)
 
#define page_to_pfn __page_to_pfn
#define pfn_to_page __pfn_to_page
 
#endif /* __ASSEMBLY__ */
 
#endif