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=-24.8 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_AGENT_SANE_1,USER_IN_DEF_DKIM_WL autolearn=unavailable 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 E847FC433B4 for ; Fri, 21 May 2021 02:17:18 +0000 (UTC) Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by mail.kernel.org (Postfix) with ESMTP id 663A96121E for ; Fri, 21 May 2021 02:17:18 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 663A96121E 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 C782194000A; Thu, 20 May 2021 22:17:17 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id C29628D0001; Thu, 20 May 2021 22:17:17 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id AC8CC94000A; Thu, 20 May 2021 22:17:17 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from forelay.hostedemail.com (smtprelay0141.hostedemail.com [216.40.44.141]) by kanga.kvack.org (Postfix) with ESMTP id 7E4CF8D0001 for ; Thu, 20 May 2021 22:17:17 -0400 (EDT) Received: from smtpin02.hostedemail.com (10.5.19.251.rfc1918.com [10.5.19.251]) by forelay03.hostedemail.com (Postfix) with ESMTP id 1BC1482499A8 for ; Fri, 21 May 2021 02:17:17 +0000 (UTC) X-FDA: 78163626114.02.6195188 Received: from mail-ot1-f43.google.com (mail-ot1-f43.google.com [209.85.210.43]) by imf03.hostedemail.com (Postfix) with ESMTP id B735CC0042C3 for ; Fri, 21 May 2021 02:17:14 +0000 (UTC) Received: by mail-ot1-f43.google.com with SMTP id g7-20020a9d12870000b0290328b1342b73so8866633otg.9 for ; Thu, 20 May 2021 19:17:16 -0700 (PDT) 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 :user-agent:mime-version; bh=t/w/mdGLNnOXLQYr7jv5WVlJPz9gV76Ic4ZwCQsYHQU=; b=HzVlX4/PKsp5/djiXIBO3cFtOzAIgz8yEz+K3cDYNdeO77HnFJFieGJJMSGKm5p0CC FhNKkQyJNAMlSSR29Qe1EAXeal+tpq1B7m0ZwRTwQRePfoOXQTUT0L9zpm5R+Y249nDM 5HenaywadS5Hzq2C6dtkZqPPbAnMIbj/G03hWtzch+U5hHaG+T6Ru/WsebK5mevSwLuq /3xYj3gaiw432cb8q39+bhuiAyAQNGbF8iIsNWr4oTy1pqQRQo+X4YbLDQEVOeb2krZL SM64vSXO+xZaBmTbg8EjRUTUNq4ookKlYJdzQzBh0fHDTOlkG/9Y2iOIVQk1uTSPhLR+ Iqfg== 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:user-agent:mime-version; bh=t/w/mdGLNnOXLQYr7jv5WVlJPz9gV76Ic4ZwCQsYHQU=; b=knGS2bJfDmQZ1RC8a0vKcyL1IR6gTK3j5YRgLJLCTKNrcJtd6yBbOqgdMbl0tApLmx 61QfpA1HZHYSbOrGXdX3ZNPXbUm5llsOk9EMr3sgQKm7bkzubSeVogkAR1cakFvosmzj gjhi3/91iQy4+Od2GpTpwKmIynApbBnb2gdFcKNNuloPaegGHTGc165BV2q4LRq12pIR ZVOawaeSOS5LV0jQXZB7JRtOuWiDFRVla9PxMM4qWnz+5CkMn8DmN5EpM8xJ97xWDpTu jAFOwFDeGwxwFEVqd4Qx0oK0bGtegRSMnOeQjkFMTvH38TFMk2c1JJnHj/JcdUQlNxfY YdqA== X-Gm-Message-State: AOAM530HV/XyENzj5vy5RIJYFP6fDWS3EEV1Z5NY1VFLEqYX9RD3+vE1 UBCRvlsFeOLFNqU8y62f5L8K2g== X-Google-Smtp-Source: ABdhPJyPe5NNa0oHjXXPCVjOcLXSuJznZBJixxDYKqVRO/BeBB3wxknifz63gY1s4kmcrkYCmgAAlQ== X-Received: by 2002:a9d:6081:: with SMTP id m1mr6206081otj.226.1621563435953; Thu, 20 May 2021 19:17:15 -0700 (PDT) Received: from eggly.attlocal.net (172-10-233-147.lightspeed.sntcca.sbcglobal.net. [172.10.233.147]) by smtp.gmail.com with ESMTPSA id p5sm904983oip.35.2021.05.20.19.17.14 (version=TLS1 cipher=ECDHE-ECDSA-AES128-SHA bits=128/128); Thu, 20 May 2021 19:17:15 -0700 (PDT) Date: Thu, 20 May 2021 19:17:04 -0700 (PDT) From: Hugh Dickins X-X-Sender: hugh@eggly.anvils To: Anshuman Khandual cc: Andrew Morton , Zi Yan , Yang Shi , "Kirill A. Shutemov" , linux-kernel@vger.kernel.org, linux-mm@kvack.org Subject: Re: [PATCH] mm/thp: Update mm_struct's MM_ANONPAGES stat for huge zero pages In-Reply-To: <1621313300-1118-1-git-send-email-anshuman.khandual@arm.com> Message-ID: References: <1621313300-1118-1-git-send-email-anshuman.khandual@arm.com> User-Agent: Alpine 2.11 (LSU 23 2013-08-11) MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Authentication-Results: imf03.hostedemail.com; dkim=pass header.d=google.com header.s=20161025 header.b="HzVlX4/P"; spf=pass (imf03.hostedemail.com: domain of hughd@google.com designates 209.85.210.43 as permitted sender) smtp.mailfrom=hughd@google.com; dmarc=pass (policy=reject) header.from=google.com X-Rspamd-Server: rspam01 X-Rspamd-Queue-Id: B735CC0042C3 X-Stat-Signature: 7jq45k8rrwcgwwrexnk9fs4xuocqtd7w X-HE-Tag: 1621563434-826185 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 Tue, 18 May 2021, Anshuman Khandual wrote: > Although the zero huge page is being shared across various processes, each > mapping needs to update its mm_struct's MM_ANONPAGES stat by HPAGE_PMD_NR > to be consistent. This just updates the stats in set_huge_zero_page() after > the mapping gets created and in zap_huge_pmd() when mapping gets destroyed. > > Cc: Andrew Morton > Cc: Zi Yan > Cc: linux-mm@kvack.org > Cc: linux-kernel@vger.kernel.org > Signed-off-by: Anshuman Khandual NAK. For consistency with what? In the all the years that the huge zero page has existed, it has been intentionally exempted from rss accounting: consistent with the small zero page, which itself has always been intentionally exempted from rss accounting. In fact, that's a good part of the reason the huge zero page was introduced (see 4a6c1297268c). To change that now will break any users depending on it. Not to mention the BUG: Bad rss-counter state mm:00000000aa61ef82 type:MM_ANONPAGES val:512 I just got from mmotm. Hugh > --- > This applies on v5.13-rc2. > > Changes in V1: > > - Updated MM_ANONPAGES stat in zap_huge_pmd() > - Updated the commit message > > Changes in RFC: > > https://lore.kernel.org/linux-mm/1620890438-9127-1-git-send-email-anshuman.khandual@arm.com/ > > mm/huge_memory.c | 2 ++ > 1 file changed, 2 insertions(+) > > diff --git a/mm/huge_memory.c b/mm/huge_memory.c > index 63ed6b25deaa..306d0a41bf75 100644 > --- a/mm/huge_memory.c > +++ b/mm/huge_memory.c > @@ -706,6 +706,7 @@ static void set_huge_zero_page(pgtable_t pgtable, struct mm_struct *mm, > if (pgtable) > pgtable_trans_huge_deposit(mm, pmd, pgtable); > set_pmd_at(mm, haddr, pmd, entry); > + add_mm_counter(mm, MM_ANONPAGES, HPAGE_PMD_NR); > mm_inc_nr_ptes(mm); > } > > @@ -1678,6 +1679,7 @@ int zap_huge_pmd(struct mmu_gather *tlb, struct vm_area_struct *vma, > tlb_remove_page_size(tlb, pmd_page(orig_pmd), HPAGE_PMD_SIZE); > } else if (is_huge_zero_pmd(orig_pmd)) { > zap_deposited_table(tlb->mm, pmd); > + add_mm_counter(tlb->mm, MM_ANONPAGES, -HPAGE_PMD_NR); > spin_unlock(ptl); > tlb_remove_page_size(tlb, pmd_page(orig_pmd), HPAGE_PMD_SIZE); > } else { > -- > 2.20.1