From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751338AbcEJHtv (ORCPT ); Tue, 10 May 2016 03:49:51 -0400 Received: from mx2.suse.de ([195.135.220.15]:54495 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751214AbcEJHhJ (ORCPT ); Tue, 10 May 2016 03:37:09 -0400 From: Vlastimil Babka To: Michal Hocko Cc: linux-mm@kvack.org, Andrew Morton , Joonsoo Kim , Rik van Riel , David Rientjes , Mel Gorman , Johannes Weiner , Tetsuo Handa , linux-kernel@vger.kernel.org, Linus Torvalds , Vlastimil Babka Subject: [RFC 03/13] mm, page_alloc: don't retry initial attempt in slowpath Date: Tue, 10 May 2016 09:35:53 +0200 Message-Id: <1462865763-22084-4-git-send-email-vbabka@suse.cz> X-Mailer: git-send-email 2.8.2 In-Reply-To: <1462865763-22084-1-git-send-email-vbabka@suse.cz> References: <1462865763-22084-1-git-send-email-vbabka@suse.cz> Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org After __alloc_pages_slowpath() sets up new alloc_flags and wakes up kswapd, it first tries get_page_from_freelist() with the new alloc_flags, as it may succeed e.g. due to using min watermark instead of low watermark. This attempt does not have to be retried on each loop, since direct reclaim, direct compaction and oom call get_page_from_freelist() themselves. This patch therefore moves the initial attempt above the retry label. The ALLOC_NO_WATERMARKS attempt is kept under retry label as it's special and should be retried after each loop. Kswapd wakeups are also done on each retry to be safe from potential races resulting in kswapd going to sleep while a process (that may not be able to reclaim by itself) is still looping. Signed-off-by: Vlastimil Babka --- mm/page_alloc.c | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/mm/page_alloc.c b/mm/page_alloc.c index 91fbf6f95403..7249949d65ca 100644 --- a/mm/page_alloc.c +++ b/mm/page_alloc.c @@ -3586,16 +3586,23 @@ __alloc_pages_slowpath(gfp_t gfp_mask, unsigned int order, */ alloc_flags = gfp_to_alloc_flags(gfp_mask); -retry: if (gfp_mask & __GFP_KSWAPD_RECLAIM) wake_all_kswapds(order, ac); - /* This is the last chance, in general, before the goto nopage. */ + /* + * The adjusted alloc_flags might result in immediate success, so try + * that first + */ page = get_page_from_freelist(gfp_mask, order, alloc_flags & ~ALLOC_NO_WATERMARKS, ac); if (page) goto got_pg; +retry: + /* Ensure kswapd doesn't accidentaly go to sleep as long as we loop */ + if (gfp_mask & __GFP_KSWAPD_RECLAIM) + wake_all_kswapds(order, ac); + /* Allocate without watermarks if the context allows */ if (alloc_flags & ALLOC_NO_WATERMARKS) { /* -- 2.8.2