diff options
author | Andrew Morton <[email protected]> | 2007-07-24 12:02:40 -0700 |
---|---|---|
committer | Linus Torvalds <[email protected]> | 2007-07-24 12:24:59 -0700 |
commit | b8c1c5da1520977cb55a358f20fc09567d40cad9 (patch) | |
tree | c762e6ad77297beed0978337ce2f5b0c50add739 | |
parent | 01e457cfcd5b6b6f18d0bb8cec0c5d43df56557e (diff) |
slab: correctly handle __GFP_ZERO
Use the correct local variable when calling into the page allocator. Local
`flags' can have __GFP_ZERO set, which causes us to pass __GFP_ZERO into the
page allocator, possibly from illegal contexts. The page allocator will later
do prep_zero_page()->kmap_atomic(..., KM_USER0) from irq contexts and will
then go BUG.
Cc: Mike Galbraith <[email protected]>
Acked-by: Christoph Lameter <[email protected]>
Signed-off-by: Andrew Morton <[email protected]>
Signed-off-by: Linus Torvalds <[email protected]>
-rw-r--r-- | mm/slab.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/mm/slab.c b/mm/slab.c index bde271c001ba..a684778b2b41 100644 --- a/mm/slab.c +++ b/mm/slab.c @@ -2776,7 +2776,7 @@ static int cache_grow(struct kmem_cache *cachep, * 'nodeid'. */ if (!objp) - objp = kmem_getpages(cachep, flags, nodeid); + objp = kmem_getpages(cachep, local_flags, nodeid); if (!objp) goto failed; |