Received: by 2002:a25:ef43:0:0:0:0:0 with SMTP id w3csp131710ybm; Thu, 28 May 2020 18:10:57 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyUiZl0f1wue9CRvMiAjUKd2WRyXarL5w8u0vJsuDSHmdhgvWzw4S79YlW9NtLU5fAZ1fkj X-Received: by 2002:a17:906:8242:: with SMTP id f2mr5329612ejx.503.1590714656993; Thu, 28 May 2020 18:10:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1590714656; cv=none; d=google.com; s=arc-20160816; b=Lt0MdLRq8Kt10CV/kJ3n3Ct73QXMGwH2H+AeIRWj817KuvrSdcazO6SpQu2+L8ojbh 0jOmteez83FDdrDHkd+6LkTqPyH82pRFG54ZfCWnXEhHDrWy6Z29pFm4TYF4zT+pGsNV H0s0caO2jAWkJiIYOO5CwCxecloSRVlfUTJvoNOfXAua4KBV8jnMk9hsIRH9y85wNz6d qaNLXeMGVGMjsnNJzKHpK1qwbadi9tdRSObw5ftqd5ZjA27s8C2edAnN82LbyrEylCFT UsH8yKhWhTxGkMFn2mDzitSbx8HxgGp3ombOhCioOlxYNtVZMIN+9P2dbJk1Q/NuX57T MMgg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:ironport-sdr:ironport-sdr; bh=vMy1/iwU1SkaX6ugffcIagERXf6O8mWu1ZRkbZUwkBA=; b=xytQ/g+2Tw3MZDCXdOBFhH68WCpAwj7LqgVbfIhrIBdkdRU2hX0t56BPhsdAPNcV2v dbAjjvIyqSkZwZx9qKXkk3td2eZ9OF8OHWJB6sorYT+mEN8ydegyUeDnzhdeZRC8eI9U LeF8XDpkoRM3B8CHaWdakqImIh6/3Ud94UQx25EAhnmX6BuFkwrxBMyBzTvWFT1a9m/G CUuML5vU8X//kkNTKNOCRDn5RQJstru1RgQ0axjllvxsXktGJQtFOQmE5wSsF7ieiBfT n67wOuZdHue2UnCnR7VgIgWYaFQCJuA7ln7SSHYmAhLvaxYxoQUjj6Shb2IYHsD1eWJ+ Q/vA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id cx19si1700541edb.395.2020.05.28.18.10.34; Thu, 28 May 2020 18:10:56 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2438310AbgE2BGZ (ORCPT + 99 others); Thu, 28 May 2020 21:06:25 -0400 Received: from mga17.intel.com ([192.55.52.151]:2379 "EHLO mga17.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2438304AbgE2BGW (ORCPT ); Thu, 28 May 2020 21:06:22 -0400 IronPort-SDR: W4H08RM+g9uyUieDuJVkzqwtHdGr1yvVrTVfvHWPuu1fSGG+uFpPxzCStXIhd0ZD8FFBu6wpUO yzUqfDEKSiMA== X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga005.jf.intel.com ([10.7.209.41]) by fmsmga107.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 28 May 2020 18:06:22 -0700 IronPort-SDR: XQoQpnrS+4xFfOoDQX7PM+NvMtEzY0KYWFvbVJVP6f3UZ1aedMbPSk0G7zOAjoXi/aB9lLwgtq o6qbvV0VJD8w== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.73,446,1583222400"; d="scan'208";a="443187402" Received: from shbuild999.sh.intel.com ([10.239.146.107]) by orsmga005.jf.intel.com with ESMTP; 28 May 2020 18:06:19 -0700 From: Feng Tang To: Andrew Morton , Michal Hocko , Johannes Weiner , Matthew Wilcox , Mel Gorman , Kees Cook , Qian Cai , andi.kleen@intel.com, tim.c.chen@intel.com, dave.hansen@intel.com, ying.huang@intel.com, linux-mm@kvack.org, linux-kernel@vger.kernel.org Cc: Feng Tang Subject: [PATCH v4 2/4] mm/util.c: make vm_memory_committed() more accurate Date: Fri, 29 May 2020 09:06:08 +0800 Message-Id: <1590714370-67182-3-git-send-email-feng.tang@intel.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1590714370-67182-1-git-send-email-feng.tang@intel.com> References: <1590714370-67182-1-git-send-email-feng.tang@intel.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org percpu_counter_sum_positive() will provide more accurate info. As with percpu_counter_read_positive(), in worst case the deviation could be 'batch * nr_cpus', which is totalram_pages/256 for now, and will be more when the batch gets enlarged. Its time cost is about 800 nanoseconds on a 2C/4T platform and 2~3 microseconds on a 2S/36C/72T server in normal case, and in worst case where vm_committed_as's spinlock is under severe contention, it costs 30~40 microseconds for the 2S/36C/72T sever, which should be fine for its only two users: /proc/meminfo and HyperV balloon driver's status trace per second. Signed-off-by: Feng Tang --- mm/util.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/mm/util.c b/mm/util.c index 9b3be03..3c7a08c 100644 --- a/mm/util.c +++ b/mm/util.c @@ -790,7 +790,7 @@ struct percpu_counter vm_committed_as ____cacheline_aligned_in_smp; */ unsigned long vm_memory_committed(void) { - return percpu_counter_read_positive(&vm_committed_as); + return percpu_counter_sum_positive(&vm_committed_as); } EXPORT_SYMBOL_GPL(vm_memory_committed); -- 2.7.4