diff options
author | Martin Hicks <mort@sgi.com> | 2005-06-21 17:14:42 -0700 |
---|---|---|
committer | Linus Torvalds <torvalds@ppc970.osdl.org> | 2005-06-21 18:46:14 -0700 |
commit | 0c35bbadc59f5ed105c34471143eceb4c0dd9c95 (patch) | |
tree | d82de388e8c0a38fa4b1d27ad372e84c9f01e013 /mm/page_alloc.c | |
parent | 753ee728964e5afb80c17659cc6c3a6fd0a42fe0 (diff) | |
download | kernel-crypto-0c35bbadc59f5ed105c34471143eceb4c0dd9c95.tar.gz kernel-crypto-0c35bbadc59f5ed105c34471143eceb4c0dd9c95.tar.xz kernel-crypto-0c35bbadc59f5ed105c34471143eceb4c0dd9c95.zip |
[PATCH] VM: add __GFP_NORECLAIM
When using the early zone reclaim, it was noticed that allocating new pages
that should be spread across the whole system caused eviction of local pages.
This adds a new GFP flag to prevent early reclaim from happening during
certain allocation attempts. The example that is implemented here is for page
cache pages. We want page cache pages to be spread across the whole system,
and we don't want page cache pages to evict other pages to get local memory.
Signed-off-by: Martin Hicks <mort@sgi.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'mm/page_alloc.c')
-rw-r--r-- | mm/page_alloc.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/mm/page_alloc.c b/mm/page_alloc.c index 3c0f69ded6b..a9da20bc2ed 100644 --- a/mm/page_alloc.c +++ b/mm/page_alloc.c @@ -729,6 +729,8 @@ should_reclaim_zone(struct zone *z, unsigned int gfp_mask) { if (!z->reclaim_pages) return 0; + if (gfp_mask & __GFP_NORECLAIM) + return 0; return 1; } |