On Thu, Oct 16, 2014 at 11:35:51AM +0800, Hui Zhu wrote: > If page alloc function __rmqueue try to get pages from MIGRATE_MOVABLE and > conditions (cma_alloc_counter, cma_aggressive_free_min, cma_alloc_counter) > allow, MIGRATE_CMA will be allocated as MIGRATE_MOVABLE first. > > Signed-off-by: Hui Zhu <zhuhui@xxxxxxxxxx> > --- > mm/page_alloc.c | 42 +++++++++++++++++++++++++++++++----------- > 1 file changed, 31 insertions(+), 11 deletions(-) > > diff --git a/mm/page_alloc.c b/mm/page_alloc.c > index 736d8e1..87bc326 100644 > --- a/mm/page_alloc.c > +++ b/mm/page_alloc.c > @@ -65,6 +65,10 @@ > #include <asm/div64.h> > #include "internal.h" > > +#ifdef CONFIG_CMA_AGGRESSIVE > +#include <linux/cma.h> > +#endif > + > /* prevent >1 _updater_ of zone percpu pageset ->high and ->batch fields */ > static DEFINE_MUTEX(pcp_batch_high_lock); > #define MIN_PERCPU_PAGELIST_FRACTION (8) > @@ -1189,20 +1193,36 @@ static struct page *__rmqueue(struct zone *zone, unsigned int order, > { > struct page *page; > > -retry_reserve: > +#ifdef CONFIG_CMA_AGGRESSIVE > + if (cma_aggressive_switch > + && migratetype == MIGRATE_MOVABLE > + && atomic_read(&cma_alloc_counter) == 0 > + && global_page_state(NR_FREE_CMA_PAGES) > cma_aggressive_free_min > + + (1 << order)) > + migratetype = MIGRATE_CMA; > +#endif > +retry: I don't get it why cma_alloc_counter should be tested. When cma alloc is progress, pageblock is isolated so that pages on that pageblock cannot be allocated. Why should we prevent aggressive allocation in this case? Thanks. -- 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>