Commit bc4ba393 authored by Christoph Lameter's avatar Christoph Lameter Committed by Linus Torvalds

[PATCH] drain_node_page(): Drain pages in batch units

drain_node_pages() currently drains the complete pageset of all pages.  If
there are a large number of pages in the queues then we may hold off
interrupts for too long.

Duplicate the method used in free_hot_cold_page.  Only drain pcp->batch
pages at one time.
Signed-off-by: default avatarChristoph Lameter <clameter@sgi.com>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent ebe29738
...@@ -685,9 +685,15 @@ void drain_node_pages(int nodeid) ...@@ -685,9 +685,15 @@ void drain_node_pages(int nodeid)
pcp = &pset->pcp[i]; pcp = &pset->pcp[i];
if (pcp->count) { if (pcp->count) {
int to_drain;
local_irq_save(flags); local_irq_save(flags);
free_pages_bulk(zone, pcp->count, &pcp->list, 0); if (pcp->count >= pcp->batch)
pcp->count = 0; to_drain = pcp->batch;
else
to_drain = pcp->count;
free_pages_bulk(zone, to_drain, &pcp->list, 0);
pcp->count -= to_drain;
local_irq_restore(flags); local_irq_restore(flags);
} }
} }
......
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