73e5745aef34ad7bf23061401b5719a925896b89
2 * Written by Pat Gaughen (gone@us.ibm.com) Mar 2002
6 #ifndef _ASM_X86_MMZONE_32_H
7 #define _ASM_X86_MMZONE_32_H
12 extern struct pglist_data
*node_data
[];
13 #define NODE_DATA(nid) (node_data[nid])
15 #include <asm/numaq.h>
16 /* summit or generic arch */
19 extern void resume_map_numa_kva(pgd_t
*pgd
);
21 #else /* !CONFIG_NUMA */
23 static inline void resume_map_numa_kva(pgd_t
*pgd
) {}
25 #endif /* CONFIG_NUMA */
27 #ifdef CONFIG_DISCONTIGMEM
30 * generic node memory support, the following assumptions apply:
32 * 1) memory comes in 64Mb contiguous chunks which are either present or not
33 * 2) we will not have more than 64Gb in total
35 * for now assume that 64Gb is max amount of RAM for whole system
36 * 64Gb / 4096bytes/page = 16777216 pages
38 #define MAX_NR_PAGES 16777216
39 #define MAX_ELEMENTS 1024
40 #define PAGES_PER_ELEMENT (MAX_NR_PAGES/MAX_ELEMENTS)
42 extern s8 physnode_map
[];
44 static inline int pfn_to_nid(unsigned long pfn
)
47 return((int) physnode_map
[(pfn
) / PAGES_PER_ELEMENT
]);
54 * Following are macros that each numa implmentation must define.
57 #define node_start_pfn(nid) (NODE_DATA(nid)->node_start_pfn)
58 #define node_end_pfn(nid) \
60 pg_data_t *__pgdat = NODE_DATA(nid); \
61 __pgdat->node_start_pfn + __pgdat->node_spanned_pages; \
64 static inline int pfn_valid(int pfn
)
66 int nid
= pfn_to_nid(pfn
);
69 return (pfn
< node_end_pfn(nid
));
73 #endif /* CONFIG_DISCONTIGMEM */
75 #ifdef CONFIG_NEED_MULTIPLE_NODES
76 /* always use node 0 for bootmem on this numa platform */
77 #define bootmem_arch_preferred_node(__bdata, size, align, goal, limit) \
79 #endif /* CONFIG_NEED_MULTIPLE_NODES */
81 #endif /* _ASM_X86_MMZONE_32_H */
This page took 0.032394 seconds and 4 git commands to generate.