Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp1102910iog; Wed, 15 Jun 2022 21:31:41 -0700 (PDT) X-Google-Smtp-Source: AGRyM1tHLD5Vr/cbqdirFCub5ikt6Fy9WnnxS1ub20QA+nDJQK5RcUQRjzPCjuLL5QdMXasNw8zD X-Received: by 2002:a05:6a00:4504:b0:51b:f04e:a130 with SMTP id cw4-20020a056a00450400b0051bf04ea130mr3043476pfb.52.1655353900849; Wed, 15 Jun 2022 21:31:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655353900; cv=none; d=google.com; s=arc-20160816; b=Pn2cKncXu40iQOuolVx9xP8vRnlEv0ldqRnMDRtsQ3kf1GwLfQIGsDAc0tYaLZawpc waB0vOVOoj/O2s8JeH7iMaabmMra9pWieG68bidldkf0ck64YBcXS3NzCV7m3E1vPR1I 7YFwjCNz+eYqYFcc18qgAjwm19gn82IN4G1FtT1Q3Me5SA1sICQJJTPARw2hCSmClPt5 NQxTEORTS3M9K+QB8exycHkoXd4qIvqGFsRQ7+Nx1rWmRak8/JAl3ZXFuSOQWQfnmnWG IBhsj7qhks/6HDDHL1gvqTFE/9bCt1RBxi6SV7Bpi58LA4IpvRI5iLjnhn1ulBThnLkk 4wcw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:date:cc:to:from:subject :message-id:dkim-signature; bh=Eik8yDSufYc1nTS6clL8XGI9b9svOM63pN8wd+B0sS4=; b=BZUFbwQ+SEv6TbHCRecM6ICq5Z7DPLpwpuAVF6F1qNVz3oIbrdcSBWAGqjcu1owSNI WlhHPLHxHJYGiEQaOdRWaUN7MjhKRMzheG+b4YEluuBzZReRKjHiAnxdGkypKSSY5XPI Mr4e+M4hhic7nMokxRKZV6BEt5s/QAj0OTM1MZhkULIH+qYx80+db0p3+otQQ9u5Xoto Ef5yZ5fIEMehBpaSxbM+q6NJj2iLQWxd+JsBHzBI14+sWSfDPTj69wDU+zXuz9jq1/Zh sXmDHkNg9LqyXHNDyJXq8GUSfs0TA4hOQsW3LdLetBZQW4AzdX85C0VzIr/wCiH3a7YV ZkEg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=A0CKMjfJ; 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=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id k18-20020a170902ce1200b00168ddc71b6csi1188910plg.617.2022.06.15.21.31.07; Wed, 15 Jun 2022 21:31:40 -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; dkim=pass header.i=@intel.com header.s=Intel header.b=A0CKMjfJ; 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=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1350217AbiFPEP0 (ORCPT + 99 others); Thu, 16 Jun 2022 00:15:26 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56878 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1358690AbiFPENO (ORCPT ); Thu, 16 Jun 2022 00:13:14 -0400 Received: from mga06.intel.com (mga06b.intel.com [134.134.136.31]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 26C7F58E79 for ; Wed, 15 Jun 2022 21:12:58 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1655352778; x=1686888778; h=message-id:subject:from:to:cc:date:in-reply-to: references:mime-version:content-transfer-encoding; bh=Nlm6al6P2Z1ikmMxhWHFF1HPFaPtHUR/HHWwJb+v9bI=; b=A0CKMjfJLP+PAjiQ/GCp9ZYYcCxK6iuKj0UwOoXhxRG14zNTqiiCAei7 cxPy8x4PvwmQwa2TNzJg/lgxn+szpr28Cpr3TTKcb8qE36MJR7VHM2rFN m1UvKLGP01uot1aXXg+Ip3yRKQug1jnHqfMEe6jmiUZXySmH4SBG+RBGu OIlYm/3iCqvjXrybH+EoiwLXyiABeYGU7PuPXxMsWrBtY3ZWboBNqSdtW /RPUtt1B4ethqHXnLDQ2uY356qiyppBu5HvaSA2fgDWvrh4ooss3csSmU /O3AxxBCo+K2s97JvPDYx+49pizNIJfiaiMo21Rxiqq9NzrbsnBoNgEDX Q==; X-IronPort-AV: E=McAfee;i="6400,9594,10379"; a="340816689" X-IronPort-AV: E=Sophos;i="5.91,304,1647327600"; d="scan'208";a="340816689" Received: from fmsmga004.fm.intel.com ([10.253.24.48]) by orsmga104.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 15 Jun 2022 21:12:48 -0700 X-IronPort-AV: E=Sophos;i="5.91,304,1647327600"; d="scan'208";a="652991681" Received: from schen9-mobl.amr.corp.intel.com ([10.209.78.147]) by fmsmga004-auth.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 15 Jun 2022 21:12:47 -0700 Message-ID: Subject: Re: [RFC PATCH 2/3] mm/memory-tiers: Use page counter to track toptier memory usage From: Tim Chen To: Wei Xu Cc: Linux MM , Andrew Morton , Huang Ying , Greg Thelen , Yang Shi , Davidlohr Bueso , Brice Goglin , Michal Hocko , Linux Kernel Mailing List , Hesham Almatary , Dave Hansen , Jonathan Cameron , Alistair Popple , Dan Williams , Feng Tang , Jagdish Gediya , Baolin Wang , David Rientjes , "Aneesh Kumar K . V" , Shakeel Butt Date: Wed, 15 Jun 2022 21:12:47 -0700 In-Reply-To: References: Content-Type: text/plain; charset="UTF-8" User-Agent: Evolution 3.34.4 (3.34.4-1.fc31) MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-5.5 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_EF,RCVD_IN_DNSWL_MED,SPF_HELO_NONE, SPF_NONE,T_SCC_BODY_TEXT_LINE 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 On Tue, 2022-06-14 at 17:30 -0700, Wei Xu wrote: Thanks for your comments. > When we don't know which pages are being charged, we should still > charge the usage to toptier (assuming that toptier always include the > default tier), e.g. from try_charge_memcg(). > I delayed the charging of the toptier a bit till we know which page is being used and the memcg is being assigned to the page. That's when mem_cgroup_charge_toptier is invoked. Otherwise if we charge to toptier first, we will have additional work to deduct the count when pages used are not toptier. > The idea is that when lower tier memory is not used, memcg->toptier > and memcg->memory should have the same value. Otherwise, it can cause > confusions about where the pages of (memcg->memory - memcg->toptier) > go. Any difference should be very small as the charge will go into toptier too quickly. The values will be different even if memcg->memory is read at slightly different time anyway. Tim