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 | |
| 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>
| -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 | ||||
| -rw-r--r-- | mm/page_alloc.c | 6 |
4 files changed, 8 insertions, 12 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 | ||
diff --git a/mm/page_alloc.c b/mm/page_alloc.c index 349b328763b7..8dc8f2735d22 100644 --- a/mm/page_alloc.c +++ b/mm/page_alloc.c | |||
| @@ -2042,7 +2042,6 @@ static __meminit void init_currently_empty_zone(struct zone *zone, | |||
| 2042 | zone_wait_table_init(zone, size); | 2042 | zone_wait_table_init(zone, size); |
| 2043 | pgdat->nr_zones = zone_idx(zone) + 1; | 2043 | pgdat->nr_zones = zone_idx(zone) + 1; |
| 2044 | 2044 | ||
| 2045 | zone->zone_mem_map = pfn_to_page(zone_start_pfn); | ||
| 2046 | zone->zone_start_pfn = zone_start_pfn; | 2045 | zone->zone_start_pfn = zone_start_pfn; |
| 2047 | 2046 | ||
| 2048 | memmap_init(size, pgdat->node_id, zone_idx(zone), zone_start_pfn); | 2047 | memmap_init(size, pgdat->node_id, zone_idx(zone), zone_start_pfn); |
| @@ -2768,9 +2767,8 @@ struct page *pfn_to_page(unsigned long pfn) | |||
| 2768 | } | 2767 | } |
| 2769 | unsigned long page_to_pfn(struct page *page) | 2768 | unsigned long page_to_pfn(struct page *page) |
| 2770 | { | 2769 | { |
| 2771 | struct zone *zone = page_zone(page); | 2770 | struct pglist_data *pgdat = NODE_DATA(page_to_nid(page)); |
| 2772 | return (page - zone->zone_mem_map) + zone->zone_start_pfn; | 2771 | return (page - pgdat->node_mem_map) + pgdat->node_start_pfn; |
| 2773 | |||
| 2774 | } | 2772 | } |
| 2775 | #elif defined(CONFIG_SPARSEMEM) | 2773 | #elif defined(CONFIG_SPARSEMEM) |
| 2776 | struct page *pfn_to_page(unsigned long pfn) | 2774 | struct page *pfn_to_page(unsigned long pfn) |
