diff options
author | KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com> | 2006-03-27 04:15:55 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-03-27 11:44:47 -0500 |
commit | a0140c1d85637ee5f4ea7c78f066e3611a6a79dc (patch) | |
tree | 7a52892e57ff7a97a3aabf920891b68ca8bf578a /include | |
parent | 0ecd702bcb924d5fb7f687e09986f688336ac896 (diff) |
[PATCH] remove zone_mem_map
This patch removes zone_mem_map.
pfn_to_page uses pgdat, page_to_pfn uses zone. page_to_pfn can use pgdat
instead of zone, which is only one user of zone_mem_map. By modifing it,
we can remove zone_mem_map.
Signed-off-by: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
Cc: Dave Hansen <haveblue@us.ibm.com>
Cc: Christoph Lameter <christoph@lameter.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'include')
-rw-r--r-- | include/asm-alpha/mmzone.h | 3 | ||||
-rw-r--r-- | include/asm-generic/memory_model.h | 10 | ||||
-rw-r--r-- | include/linux/mmzone.h | 1 |
3 files changed, 6 insertions, 8 deletions
diff --git a/include/asm-alpha/mmzone.h b/include/asm-alpha/mmzone.h index c9004398f273..192d80c875b0 100644 --- a/include/asm-alpha/mmzone.h +++ b/include/asm-alpha/mmzone.h | |||
@@ -83,8 +83,7 @@ PLAT_NODE_DATA_LOCALNR(unsigned long p, int n) | |||
83 | pte_t pte; \ | 83 | pte_t pte; \ |
84 | unsigned long pfn; \ | 84 | unsigned long pfn; \ |
85 | \ | 85 | \ |
86 | pfn = ((unsigned long)((page)-page_zone(page)->zone_mem_map)) << 32; \ | 86 | pfn = page_to_pfn(page) << 32; \ |
87 | pfn += page_zone(page)->zone_start_pfn << 32; \ | ||
88 | pte_val(pte) = pfn | pgprot_val(pgprot); \ | 87 | pte_val(pte) = pfn | pgprot_val(pgprot); \ |
89 | \ | 88 | \ |
90 | pte; \ | 89 | pte; \ |
diff --git a/include/asm-generic/memory_model.h b/include/asm-generic/memory_model.h index a7bb4978e808..0cfb086dd373 100644 --- a/include/asm-generic/memory_model.h +++ b/include/asm-generic/memory_model.h | |||
@@ -45,11 +45,11 @@ extern unsigned long page_to_pfn(struct page *page); | |||
45 | NODE_DATA(__nid)->node_mem_map + arch_local_page_offset(__pfn, __nid);\ | 45 | NODE_DATA(__nid)->node_mem_map + arch_local_page_offset(__pfn, __nid);\ |
46 | }) | 46 | }) |
47 | 47 | ||
48 | #define page_to_pfn(pg) \ | 48 | #define page_to_pfn(pg) \ |
49 | ({ struct page *__pg = (pg); \ | 49 | ({ struct page *__pg = (pg); \ |
50 | struct zone *__zone = page_zone(__pg); \ | 50 | struct pglist_data *__pgdat = NODE_DATA(page_to_nid(__pg)); \ |
51 | (unsigned long)(__pg - __zone->zone_mem_map) + \ | 51 | (unsigned long)(__pg - __pgdat->node_mem_map) + \ |
52 | __zone->zone_start_pfn; \ | 52 | __pgdat->node_start_pfn; \ |
53 | }) | 53 | }) |
54 | 54 | ||
55 | #elif defined(CONFIG_SPARSEMEM) | 55 | #elif defined(CONFIG_SPARSEMEM) |
diff --git a/include/linux/mmzone.h b/include/linux/mmzone.h index 0c1c0c0cce65..ace31c515a8c 100644 --- a/include/linux/mmzone.h +++ b/include/linux/mmzone.h | |||
@@ -225,7 +225,6 @@ struct zone { | |||
225 | * Discontig memory support fields. | 225 | * Discontig memory support fields. |
226 | */ | 226 | */ |
227 | struct pglist_data *zone_pgdat; | 227 | struct pglist_data *zone_pgdat; |
228 | struct page *zone_mem_map; | ||
229 | /* zone_start_pfn == zone_start_paddr >> PAGE_SHIFT */ | 228 | /* zone_start_pfn == zone_start_paddr >> PAGE_SHIFT */ |
230 | unsigned long zone_start_pfn; | 229 | unsigned long zone_start_pfn; |
231 | 230 | ||