mirror of
https://github.com/torvalds/linux.git
synced 2024-12-31 23:31:29 +00:00
[PATCH] unify pfn_to_page: x86_64 pfn_to_page
x86_64 can use generic funcs. For DISCONTIGMEM, CONFIG_OUT_OF_LINE_PFN_TO_PAGE is selected. Signed-off-by: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com> Cc: Andi Kleen <ak@muc.de> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
This commit is contained in:
parent
ad658b385e
commit
dc8ecb4370
@ -334,6 +334,10 @@ config HAVE_ARCH_EARLY_PFN_TO_NID
|
||||
def_bool y
|
||||
depends on NUMA
|
||||
|
||||
config OUT_OF_LINE_PFN_TO_PAGE
|
||||
def_bool y
|
||||
depends on DISCONTIGMEM
|
||||
|
||||
config NR_CPUS
|
||||
int "Maximum number of CPUs (2-256)"
|
||||
range 2 255
|
||||
|
@ -377,21 +377,6 @@ EXPORT_SYMBOL(node_data);
|
||||
* Should do that.
|
||||
*/
|
||||
|
||||
/* Requires pfn_valid(pfn) to be true */
|
||||
struct page *pfn_to_page(unsigned long pfn)
|
||||
{
|
||||
int nid = phys_to_nid(((unsigned long)(pfn)) << PAGE_SHIFT);
|
||||
return (pfn - node_start_pfn(nid)) + NODE_DATA(nid)->node_mem_map;
|
||||
}
|
||||
EXPORT_SYMBOL(pfn_to_page);
|
||||
|
||||
unsigned long page_to_pfn(struct page *page)
|
||||
{
|
||||
return (long)(((page) - page_zone(page)->zone_mem_map) +
|
||||
page_zone(page)->zone_start_pfn);
|
||||
}
|
||||
EXPORT_SYMBOL(page_to_pfn);
|
||||
|
||||
int pfn_valid(unsigned long pfn)
|
||||
{
|
||||
unsigned nid;
|
||||
|
@ -44,12 +44,8 @@ static inline __attribute__((pure)) int phys_to_nid(unsigned long addr)
|
||||
#define pfn_to_nid(pfn) phys_to_nid((unsigned long)(pfn) << PAGE_SHIFT)
|
||||
#define kvaddr_to_nid(kaddr) phys_to_nid(__pa(kaddr))
|
||||
|
||||
extern struct page *pfn_to_page(unsigned long pfn);
|
||||
extern unsigned long page_to_pfn(struct page *page);
|
||||
extern int pfn_valid(unsigned long pfn);
|
||||
#endif
|
||||
|
||||
#define local_mapnr(kvaddr) \
|
||||
( (__pa(kvaddr) >> PAGE_SHIFT) - node_start_pfn(kvaddr_to_nid(kvaddr)) )
|
||||
#endif
|
||||
#endif
|
||||
|
@ -123,8 +123,6 @@ typedef struct { unsigned long pgprot; } pgprot_t;
|
||||
#define __boot_va(x) __va(x)
|
||||
#define __boot_pa(x) __pa(x)
|
||||
#ifdef CONFIG_FLATMEM
|
||||
#define pfn_to_page(pfn) (mem_map + (pfn))
|
||||
#define page_to_pfn(page) ((unsigned long)((page) - mem_map))
|
||||
#define pfn_valid(pfn) ((pfn) < end_pfn)
|
||||
#endif
|
||||
|
||||
@ -140,6 +138,7 @@ typedef struct { unsigned long pgprot; } pgprot_t;
|
||||
|
||||
#endif /* __KERNEL__ */
|
||||
|
||||
#include <asm-generic/memory_model.h>
|
||||
#include <asm-generic/page.h>
|
||||
|
||||
#endif /* _X86_64_PAGE_H */
|
||||
|
Loading…
Reference in New Issue
Block a user