[PATCH] reduce MAX_NR_ZONES: move HIGHMEM counters into highmem.c/.h
Move totalhigh_pages and nr_free_highpages() into highmem.c/.h Move the totalhigh_pages definition into highmem.c/.h. Move the nr_free_highpages function into highmem.c [yoichi_yuasa@tripeaks.co.jp: build fix] Signed-off-by: Christoph Lameter <clameter@sgi.com> Signed-off-by: Yoichi Yuasa <yoichi_yuasa@tripeaks.co.jp> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
This commit is contained in:
		
							parent
							
								
									182e8e2373
								
							
						
					
					
						commit
						c1f60a5a41
					
				| @ -19,6 +19,7 @@ | ||||
| #include <linux/swap.h> | ||||
| #include <linux/bootmem.h> | ||||
| #include <linux/pfn.h> | ||||
| #include <linux/highmem.h> | ||||
| #include <asm/page.h> | ||||
| #include <asm/sections.h> | ||||
| 
 | ||||
|  | ||||
| @ -79,8 +79,10 @@ void mem_init(void) | ||||
| 
 | ||||
| 	/* this will put all low memory onto the freelists */ | ||||
| 	totalram_pages = free_all_bootmem(); | ||||
| #ifdef CONFIG_HIGHMEM | ||||
| 	totalhigh_pages = highmem >> PAGE_SHIFT; | ||||
| 	totalram_pages += totalhigh_pages; | ||||
| #endif | ||||
| 	num_physpages = totalram_pages; | ||||
| 	max_pfn = totalram_pages; | ||||
| 	printk(KERN_INFO "Memory: %luk available\n",  | ||||
|  | ||||
| @ -24,11 +24,14 @@ static inline void flush_kernel_dcache_page(struct page *page) | ||||
| 
 | ||||
| /* declarations for linux/mm/highmem.c */ | ||||
| unsigned int nr_free_highpages(void); | ||||
| extern unsigned long totalhigh_pages; | ||||
| 
 | ||||
| #else /* CONFIG_HIGHMEM */ | ||||
| 
 | ||||
| static inline unsigned int nr_free_highpages(void) { return 0; } | ||||
| 
 | ||||
| #define totalhigh_pages 0 | ||||
| 
 | ||||
| #ifndef ARCH_HAS_KMAP | ||||
| static inline void *kmap(struct page *page) | ||||
| { | ||||
|  | ||||
| @ -162,7 +162,6 @@ extern void swapin_readahead(swp_entry_t, unsigned long, struct vm_area_struct * | ||||
| 
 | ||||
| /* linux/mm/page_alloc.c */ | ||||
| extern unsigned long totalram_pages; | ||||
| extern unsigned long totalhigh_pages; | ||||
| extern unsigned long totalreserve_pages; | ||||
| extern long nr_swap_pages; | ||||
| extern unsigned int nr_free_pages(void); | ||||
|  | ||||
							
								
								
									
										13
									
								
								mm/highmem.c
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								mm/highmem.c
									
									
									
									
									
								
							| @ -46,6 +46,19 @@ static void *mempool_alloc_pages_isa(gfp_t gfp_mask, void *data) | ||||
|  */ | ||||
| #ifdef CONFIG_HIGHMEM | ||||
| 
 | ||||
| unsigned long totalhigh_pages __read_mostly; | ||||
| 
 | ||||
| unsigned int nr_free_highpages (void) | ||||
| { | ||||
| 	pg_data_t *pgdat; | ||||
| 	unsigned int pages = 0; | ||||
| 
 | ||||
| 	for_each_online_pgdat(pgdat) | ||||
| 		pages += pgdat->node_zones[ZONE_HIGHMEM].free_pages; | ||||
| 
 | ||||
| 	return pages; | ||||
| } | ||||
| 
 | ||||
| static int pkmap_count[LAST_PKMAP]; | ||||
| static unsigned int last_pkmap_nr; | ||||
| static  __cacheline_aligned_in_smp DEFINE_SPINLOCK(kmap_lock); | ||||
|  | ||||
| @ -51,7 +51,6 @@ EXPORT_SYMBOL(node_online_map); | ||||
| nodemask_t node_possible_map __read_mostly = NODE_MASK_ALL; | ||||
| EXPORT_SYMBOL(node_possible_map); | ||||
| unsigned long totalram_pages __read_mostly; | ||||
| unsigned long totalhigh_pages __read_mostly; | ||||
| unsigned long totalreserve_pages __read_mostly; | ||||
| long nr_swap_pages; | ||||
| int percpu_pagelist_fraction; | ||||
| @ -1185,20 +1184,6 @@ unsigned int nr_free_pagecache_pages(void) | ||||
| { | ||||
| 	return nr_free_zone_pages(gfp_zone(GFP_HIGHUSER)); | ||||
| } | ||||
| 
 | ||||
| #ifdef CONFIG_HIGHMEM | ||||
| unsigned int nr_free_highpages (void) | ||||
| { | ||||
| 	pg_data_t *pgdat; | ||||
| 	unsigned int pages = 0; | ||||
| 
 | ||||
| 	for_each_online_pgdat(pgdat) | ||||
| 		pages += pgdat->node_zones[ZONE_HIGHMEM].free_pages; | ||||
| 
 | ||||
| 	return pages; | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #ifdef CONFIG_NUMA | ||||
| static void show_node(struct zone *zone) | ||||
| { | ||||
|  | ||||
| @ -45,6 +45,7 @@ | ||||
| #include <linux/namei.h> | ||||
| #include <linux/ctype.h> | ||||
| #include <linux/migrate.h> | ||||
| #include <linux/highmem.h> | ||||
| 
 | ||||
| #include <asm/uaccess.h> | ||||
| #include <asm/div64.h> | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user