On 01/19/2017 06:07 PM, Lucas Stach wrote: > Currently alloc_contig_range assumes that the compaction should > be done with the default GFP_KERNEL flags. This is probably > right for all current uses of this interface, but may change as > CMA is used in more use-cases (including being the default DMA > memory allocator on some platforms). > > Change the function prototype, to allow for passing through the > GFP mask set by upper layers. No functional change in this patch, > just making the assumptions a bit more obvious. > > Signed-off-by: Lucas Stach <l.stach@xxxxxxxxxxxxxx> [...] > diff --git a/mm/page_alloc.c b/mm/page_alloc.c > index eced9fee582b..6d392d8dee36 100644 > --- a/mm/page_alloc.c > +++ b/mm/page_alloc.c > @@ -7230,6 +7230,7 @@ static int __alloc_contig_migrate_range(struct compact_control *cc, > * #MIGRATE_MOVABLE or #MIGRATE_CMA). All pageblocks > * in range must have the same migratetype and it must > * be either of the two. > + * @gfp_mask: GFP mask to use during compaction > * > * The PFN range does not have to be pageblock or MAX_ORDER_NR_PAGES > * aligned, however it's the caller's responsibility to guarantee that > @@ -7243,7 +7244,7 @@ static int __alloc_contig_migrate_range(struct compact_control *cc, > * need to be freed with free_contig_range(). > */ > int alloc_contig_range(unsigned long start, unsigned long end, > - unsigned migratetype) > + unsigned migratetype, gfp_t gfp_mask) > { > unsigned long outer_start, outer_end; > unsigned int order; > @@ -7255,7 +7256,7 @@ int alloc_contig_range(unsigned long start, unsigned long end, > .zone = page_zone(pfn_to_page(start)), > .mode = MIGRATE_SYNC, > .ignore_skip_hint = true, > - .gfp_mask = GFP_KERNEL, > + .gfp_mask = gfp_mask, I think you should apply memalloc_noio_flags() here (and Michal should then convert it to the new name in his scoped gfp_nofs series). Note that then it's technically a functional change, but it's needed. Otherwise looks good. > }; > INIT_LIST_HEAD(&cc.migratepages); > >