From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-23.2 required=3.0 tests=BAYES_00,DKIMWL_WL_MED, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_CR_TRAILER,INCLUDES_PATCH,MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS, URIBL_BLOCKED,USER_IN_DEF_DKIM_WL autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 8BD08C433DB for ; Mon, 1 Feb 2021 21:24:54 +0000 (UTC) Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by mail.kernel.org (Postfix) with ESMTP id EA7E164E31 for ; Mon, 1 Feb 2021 21:24:53 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org EA7E164E31 Authentication-Results: mail.kernel.org; dmarc=fail (p=reject dis=none) header.from=google.com Authentication-Results: mail.kernel.org; spf=pass smtp.mailfrom=owner-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix) id 341516B0005; Mon, 1 Feb 2021 16:24:53 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 2F1766B0006; Mon, 1 Feb 2021 16:24:53 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 205F06B006E; Mon, 1 Feb 2021 16:24:53 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from forelay.hostedemail.com (smtprelay0161.hostedemail.com [216.40.44.161]) by kanga.kvack.org (Postfix) with ESMTP id 072CA6B0005 for ; Mon, 1 Feb 2021 16:24:53 -0500 (EST) Received: from smtpin03.hostedemail.com (10.5.19.251.rfc1918.com [10.5.19.251]) by forelay01.hostedemail.com (Postfix) with ESMTP id BDFB5180AD801 for ; Mon, 1 Feb 2021 21:24:52 +0000 (UTC) X-FDA: 77770978824.03.earth24_5e176bf275c5 Received: from filter.hostedemail.com (10.5.16.251.rfc1918.com [10.5.16.251]) by smtpin03.hostedemail.com (Postfix) with ESMTP id 9EF8028A4E8 for ; Mon, 1 Feb 2021 21:24:52 +0000 (UTC) X-HE-Tag: earth24_5e176bf275c5 X-Filterd-Recvd-Size: 4552 Received: from mail-pl1-f181.google.com (mail-pl1-f181.google.com [209.85.214.181]) by imf13.hostedemail.com (Postfix) with ESMTP for ; Mon, 1 Feb 2021 21:24:52 +0000 (UTC) Received: by mail-pl1-f181.google.com with SMTP id b17so10767141plz.6 for ; Mon, 01 Feb 2021 13:24:52 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=date:from:to:cc:subject:in-reply-to:message-id:references :mime-version; bh=Stmza4ZljYVmGoBag2te1ro2TQptmpx4IjyAJp+jAIQ=; b=RTukz/I15+gomvoxURNPYBaO+iQPAJQ7j8SPTDDhq9UlRjA6hVVdohEFSjz2NLtxzu te4v/zkr2CANQypbMIiFFGvE+IgZAs8yeXiVvxbwVfWfqEyz9Kf5KYxTCiM11sw79LRr lERUPtgup7HUjlKpkk9qpnbY1hnUvEx6r1sbv0Qh1zEvsAeHMVdgD5IhyQ5QT5PO4aIG Ez1F850YBZsn3AqraRfPHUDSCungyeAeR3/3rRZAXBsP7wjLZipfQm89OmyCF9GAcO1t 0eL5xJ7Cm8fAKBZWXSTWb3Fwe8M73WqUY17YBU+udWeGB0YtyDZ33tdpC9sbCxtdQH0s o+yA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:in-reply-to:message-id :references:mime-version; bh=Stmza4ZljYVmGoBag2te1ro2TQptmpx4IjyAJp+jAIQ=; b=CRw83S4VyqE2GQKN73oi5RPdIL15faoBsAjzz/g4NXYqGQwV9CDUKzeXtHPgJUxTHa 635IQol35ms1RKllVwrIRq9K2jSOAq5Arbhn4mRLJjHJ8eP6W0FSE0B8mCsD3ZbNK3fj lIL4yey7u33kVrzjv6i6yUgXWB+qnDVogaNXaMbYkvKFUnjxGjWtInHdTD+Ty5yfjlTO lEWY8poivLrEYKTAyR4QTvjh3Xyb0pFc/l48dWQPlrH/Q4IyTmYZAj71yNSK6ywmOQFJ ZLQRZfkepnky2lb1ivCPZI9Z5jcROB0PmdhE5UUvGRkorV6eMSa6Nfp+kbaX6cVCgM/C wKUA== X-Gm-Message-State: AOAM532uftDTFilacCQ3vSSOQ47k8pLv0f656NyPxRDJytjqPdXuByam LuKjIV8k71xXeNPRqngQrk0l3A== X-Google-Smtp-Source: ABdhPJx9CNcx+6r2+pPMJecmnoC4EI/ehFFZAVeJII0hBoOBWc2uuDTyC9S6RRznVKolCYuRY9Gbrg== X-Received: by 2002:a17:902:b213:b029:db:3a3e:d8ad with SMTP id t19-20020a170902b213b02900db3a3ed8admr19643118plr.73.1612214690922; Mon, 01 Feb 2021 13:24:50 -0800 (PST) Received: from [2620:15c:17:3:4a0f:cfff:fe51:6667] ([2620:15c:17:3:4a0f:cfff:fe51:6667]) by smtp.gmail.com with ESMTPSA id y11sm18311381pfn.85.2021.02.01.13.24.49 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 01 Feb 2021 13:24:49 -0800 (PST) Date: Mon, 1 Feb 2021 13:24:49 -0800 (PST) From: David Rientjes To: Charan Teja Reddy cc: akpm@linux-foundation.org, vbabka@suse.cz, mhocko@suse.com, vinmenon@codeaurora.org, linux-mm@kvack.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] mm: page_alloc: update the COMPACT[STALL|FAIL] events properly In-Reply-To: <1612187338-19100-1-git-send-email-charante@codeaurora.org> Message-ID: References: <1612187338-19100-1-git-send-email-charante@codeaurora.org> MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: On Mon, 1 Feb 2021, Charan Teja Reddy wrote: > By defination, COMPACT[STALL|FAIL] events needs to be counted when there s/defination/definition/ > is 'At least in one zone compaction wasn't deferred or skipped from the > direct compaction'. And when compaction is skipped or deferred, > COMPACT_SKIPPED will be returned but it will still go and update these > compaction events which is wrong in the sense that COMPACT[STALL|FAIL] > is counted without even trying the compaction. > > Correct this by skipping the counting of these events when > COMPACT_SKIPPED is returned for compaction. This indirectly also avoid > the unnecessary try into the get_page_from_freelist() when compaction is > not even tried. > > Signed-off-by: Charan Teja Reddy > --- > mm/page_alloc.c | 2 ++ > 1 file changed, 2 insertions(+) > > diff --git a/mm/page_alloc.c b/mm/page_alloc.c > index 519a60d..531f244 100644 > --- a/mm/page_alloc.c > +++ b/mm/page_alloc.c > @@ -4152,6 +4152,8 @@ __alloc_pages_direct_compact(gfp_t gfp_mask, unsigned int order, > memalloc_noreclaim_restore(noreclaim_flag); > psi_memstall_leave(&pflags); > > + if (*compact_result == COMPACT_SKIPPED) > + return NULL; > /* > * At least in one zone compaction wasn't deferred or skipped, so let's > * count a compaction stall This makes sense, I wonder if it would also be useful to check that page == NULL, either in try_to_compact_pages() or here for COMPACT_SKIPPED?