Commit 9a0bd0e3 authored by Andrew Morton's avatar Andrew Morton Committed by Linus Torvalds

[PATCH] factor common code in page_alloc.c

Factor out some similar code in page_alloc.c
parent 28ea30f7
...@@ -543,16 +543,13 @@ unsigned int nr_free_pages (void) ...@@ -543,16 +543,13 @@ unsigned int nr_free_pages (void)
return sum; return sum;
} }
/* static unsigned int nr_free_zone_pages(int offset)
* Amount of free RAM allocatable as buffer memory:
*/
unsigned int nr_free_buffer_pages (void)
{ {
pg_data_t *pgdat = pgdat_list; pg_data_t *pgdat = pgdat_list;
unsigned int sum = 0; unsigned int sum = 0;
do { do {
zonelist_t *zonelist = pgdat->node_zonelists + (GFP_USER & GFP_ZONEMASK); zonelist_t *zonelist = pgdat->node_zonelists + offset;
zone_t **zonep = zonelist->zones; zone_t **zonep = zonelist->zones;
zone_t *zone; zone_t *zone;
...@@ -570,30 +567,19 @@ unsigned int nr_free_buffer_pages (void) ...@@ -570,30 +567,19 @@ unsigned int nr_free_buffer_pages (void)
} }
/* /*
* Amount of free RAM allocatable as pagecache memory: * Amount of free RAM allocatable within ZONE_DMA and ZONE_NORMAL
*/ */
unsigned int nr_free_pagecache_pages(void) unsigned int nr_free_buffer_pages(void)
{ {
pg_data_t *pgdat = pgdat_list; return nr_free_zone_pages(GFP_USER & GFP_ZONEMASK);
unsigned int sum = 0; }
do {
zonelist_t *zonelist = pgdat->node_zonelists +
(GFP_HIGHUSER & GFP_ZONEMASK);
zone_t **zonep = zonelist->zones;
zone_t *zone;
for (zone = *zonep++; zone; zone = *zonep++) {
unsigned long size = zone->size;
unsigned long high = zone->pages_high;
if (size > high)
sum += size - high;
}
pgdat = pgdat->node_next;
} while (pgdat);
return sum; /*
* Amount of free RAM allocatable within all zones
*/
unsigned int nr_free_pagecache_pages(void)
{
return nr_free_zone_pages(GFP_HIGHUSER & GFP_ZONEMASK);
} }
#if CONFIG_HIGHMEM #if CONFIG_HIGHMEM
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment