On 06/10/2016 11:38 AM, Mel Gorman wrote: > Commit d0164adc89f6 ("mm, page_alloc: distinguish between being unable to > sleep, unwilling to sleep and avoiding waking kswapd") modified __GFP_WAIT > to explicitly identify the difference between atomic callers and those that > were unwilling to sleep. Later the definition was removed entirely. > > The GFP_RECLAIM_MASK is the set of flags that affect watermark checking > and reclaim behaviour but __GFP_ATOMIC was never added. Without it, atomic > users of the slab allocator strip the __GFP_ATOMIC flag and cannot access > the page allocator atomic reserves. This patch addresses the problem. > > The user-visible impact depends on the workload but potentially atomic > allocations unnecessarily fail without this path. > > Cc: <stable@xxxxxxxxxxxxxxx> # 4.4+ > Reported-by: Marcin Wojtas <mw@xxxxxxxxxxxx> > Signed-off-by: Mel Gorman <mgorman@xxxxxxxxxxxxxxxxxxx> Acked-by: Vlastimil Babka <vbabka@xxxxxxx> > --- > mm/internal.h | 3 ++- > 1 file changed, 2 insertions(+), 1 deletion(-) > > diff --git a/mm/internal.h b/mm/internal.h > index a37e5b6f9d25..2524ec880e24 100644 > --- a/mm/internal.h > +++ b/mm/internal.h > @@ -24,7 +24,8 @@ > */ > #define GFP_RECLAIM_MASK (__GFP_RECLAIM|__GFP_HIGH|__GFP_IO|__GFP_FS|\ > __GFP_NOWARN|__GFP_REPEAT|__GFP_NOFAIL|\ > - __GFP_NORETRY|__GFP_MEMALLOC|__GFP_NOMEMALLOC) > + __GFP_NORETRY|__GFP_MEMALLOC|__GFP_NOMEMALLOC|\ > + __GFP_ATOMIC) > > /* The GFP flags allowed during early boot */ > #define GFP_BOOT_MASK (__GFP_BITS_MASK & ~(__GFP_RECLAIM|__GFP_IO|__GFP_FS)) > -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxx. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>