Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp478144iog; Thu, 30 Jun 2022 04:40:14 -0700 (PDT) X-Google-Smtp-Source: AGRyM1u/zAPwhfpUdsTZ9bktHbXffK+ujHiXeBETY3drmCgQ5RBnAlgS6HMEO5+QMC154StAPgoN X-Received: by 2002:a05:6402:280b:b0:437:9efc:a065 with SMTP id h11-20020a056402280b00b004379efca065mr11114540ede.3.1656589214760; Thu, 30 Jun 2022 04:40:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1656589214; cv=none; d=google.com; s=arc-20160816; b=IxSYbhm//5YlsIm7CztWWqZYTMNusi+rnwvOOniG/guuUDwb9II7JXRLsPuoqU+txa GC4q5bFYF3PWm1ZerJY5ZW95KLBMjBiMYhlexkB0uqjxv+Q5ye/HmziXJ2iZgrVfwhwR aQRYfXDnWwsQYFfCBKuRxKJHdEn5V1Aw5xQW3WD/1/OsHajh2BA5WQrjhCKnLd/8wQd3 JDhPTLvCqqcukvYpceU6NG98Ny+EJm6VcXx9wlFnhNyNddLIN/xD6b+oYysNTeQFl/BU c8hjEnQ/6OVquN9sinL6cdWsfjisQ1kCyVA8YLeuvk1DibaD466UMIGG+L1BXQUOLeXZ nCYA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:references:in-reply-to :message-id:date:subject:cc:to:from; bh=11VI4BaJdVZVCzF5re1KQ1hS58clfYoLG4I4dlmXXqs=; b=YjGYidU1jMdlKPxLnjlky2qsSVrkOAiFzejWEnhHaPFkkF6T2FgGFgcirq5VOjDuyh J4+KSYsDn+YFqzvvFJgMa11sKgy1lmK2JcVdiuoBgDeoCfE8UcX4LJZeau4kEhRV9EOq Hcrb167z/orxPlqpqIcXMBfD30FEFeocUWhmUsVGqwoDaNJw1OosOWe7juMJNEl9XdnU aQaoC1Cjnbwc1WfbYcp5PCcG2zt8QJzAo4bh5yJ1o2YrXIHk3ody+hXih85AFCYv3kAL yVVAZ5nw/qjhTdBWDV5phxZUVNrjCPMP/4tDeuWwvsN5xiJCmNYnZtvPEfAfM/8Oo1vm IbKA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id h2-20020aa7cdc2000000b00435bab1a7a3si2892994edw.480.2022.06.30.04.39.49; Thu, 30 Jun 2022 04:40:14 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234479AbiF3LLc (ORCPT + 99 others); Thu, 30 Jun 2022 07:11:32 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54308 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231895AbiF3LL3 (ORCPT ); Thu, 30 Jun 2022 07:11:29 -0400 Received: from out30-54.freemail.mail.aliyun.com (out30-54.freemail.mail.aliyun.com [115.124.30.54]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id D2F9045061 for ; Thu, 30 Jun 2022 04:11:28 -0700 (PDT) X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R711e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=ay29a033018046060;MF=baolin.wang@linux.alibaba.com;NM=1;PH=DS;RN=6;SR=0;TI=SMTPD_---0VHrqagJ_1656587484; Received: from localhost(mailfrom:baolin.wang@linux.alibaba.com fp:SMTPD_---0VHrqagJ_1656587484) by smtp.aliyun-inc.com; Thu, 30 Jun 2022 19:11:25 +0800 From: Baolin Wang To: akpm@linux-foundation.org Cc: rppt@linux.ibm.com, willy@infradead.org, baolin.wang@linux.alibaba.com, linux-mm@kvack.org, linux-kernel@vger.kernel.org Subject: [RFC PATCH v3 1/3] mm: Factor out the pagetable pages account into new helper function Date: Thu, 30 Jun 2022 19:11:14 +0800 Message-Id: <9c527d4d2eb1f457306e575ce16c6acdd8141e02.1656586863.git.baolin.wang@linux.alibaba.com> X-Mailer: git-send-email 1.8.3.1 In-Reply-To: References: In-Reply-To: References: X-Spam-Status: No, score=-9.9 required=5.0 tests=BAYES_00, ENV_AND_HDR_SPF_MATCH,RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS, T_SCC_BODY_TEXT_LINE,UNPARSEABLE_RELAY,USER_IN_DEF_SPF_WL autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Factor out the pagetable pages account into new helper functions to avoid duplicated code. Meanwhile these helper functions also will be used to account pagetable pages which do not need split pagetale lock. Meanwhile convert to use mod_lruvec_page_state() in case of non-order-0 page table allocation. Signed-off-by: Baolin Wang --- include/linux/mm.h | 24 ++++++++++++++++-------- 1 file changed, 16 insertions(+), 8 deletions(-) diff --git a/include/linux/mm.h b/include/linux/mm.h index a2270e3..3be6d2c 100644 --- a/include/linux/mm.h +++ b/include/linux/mm.h @@ -2353,20 +2353,30 @@ static inline void pgtable_init(void) pgtable_cache_init(); } +static inline void pgtable_page_inc(struct page *page) +{ + __SetPageTable(page); + mod_lruvec_page_state(page, NR_PAGETABLE, compound_nr(page)); +} + +static inline void pgtable_page_dec(struct page *page) +{ + __ClearPageTable(page); + mod_lruvec_page_state(page, NR_PAGETABLE, -compound_nr(page)); +} + static inline bool pgtable_pte_page_ctor(struct page *page) { if (!ptlock_init(page)) return false; - __SetPageTable(page); - inc_lruvec_page_state(page, NR_PAGETABLE); + pgtable_page_inc(page); return true; } static inline void pgtable_pte_page_dtor(struct page *page) { ptlock_free(page); - __ClearPageTable(page); - dec_lruvec_page_state(page, NR_PAGETABLE); + pgtable_page_dec(page); } #define pte_offset_map_lock(mm, pmd, address, ptlp) \ @@ -2452,16 +2462,14 @@ static inline bool pgtable_pmd_page_ctor(struct page *page) { if (!pmd_ptlock_init(page)) return false; - __SetPageTable(page); - inc_lruvec_page_state(page, NR_PAGETABLE); + pgtable_page_inc(page); return true; } static inline void pgtable_pmd_page_dtor(struct page *page) { pmd_ptlock_free(page); - __ClearPageTable(page); - dec_lruvec_page_state(page, NR_PAGETABLE); + pgtable_page_dec(page); } /* -- 1.8.3.1