Received: by 2002:ac0:950c:0:0:0:0:0 with SMTP id f12csp3212133imc; Wed, 13 Mar 2019 11:41:54 -0700 (PDT) X-Google-Smtp-Source: APXvYqzX1GwJUAOyDKURcWFgcHKaF/tj33AuD6ZYRHmchEdid92aR7p/JPHfeFi9hSf1OYt2VrzN X-Received: by 2002:a17:902:801:: with SMTP id 1mr45683695plk.299.1552502514289; Wed, 13 Mar 2019 11:41:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1552502514; cv=none; d=google.com; s=arc-20160816; b=fDk1J6Q4wMY4EwPw0GKndpQdJt290Qjwksv8MywoiFnFliNNFDAvQ1x15krNpuTB0G E+pJ2MazXLJWSFso8Wrc0MywfNJMJdbad6Zfo83ss/qEt2/D4RwlrVV15pp6Sm6I8vjE Gb2jMzcheHOTAlD2n3S/5jNrw3kkhJ3pA4tdn8DElKlbk+EPDTr0IsT0R86UqoXUeuy6 Pe+69PbcYqk3nynm4xzeXileBM055qx6JJnPMw4lGq3pWoy3cXEwgzuYgvEQuH8jFW9w 9bjotQbj2SVovnmPi7semgktzpPhVpwqPEBRe8t6KVq1cKm3Eu9osKI/GyCMY0nFSRv5 /tJQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=ZKgL4zeK+z0St01hNMYKSt6dKMvw92MkjAHduvDs3M4=; b=Mq1bvsosOJ97B3fgKnN+N+Rd+QDshFS8e+sZQWRhHgpScxZle726nYREzPjnrsQ5rN 6ydZfpEHrmLQvugiV6xwh0i4Pl/Z7F5ZlXZHAkjJxJK8m5pidXN1mmTSzeZUsPXahLhs 3sL4zxR2GsmopaPQAHZWxIRVAaXnQPeYxe4DVd0JFzukztnMh6mk1rhCS5p346Xijn1B fc5zUQMKCmIRLisFdLUBHTphFrr15IiZcICeiI9Q36kBFkLMFA0ooiHveTmWmNp5w6CD QvJImuBwsAskJ9g3JfX7l8ebmfRiOHaP83HGN+1rI5gWZFPqybfNFuEcKzIdRvUpXVwS q6eA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=TrX0uTyr; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 25si10588738pgt.419.2019.03.13.11.41.38; Wed, 13 Mar 2019 11:41:54 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=TrX0uTyr; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727043AbfCMSkr (ORCPT + 99 others); Wed, 13 Mar 2019 14:40:47 -0400 Received: from mail-pf1-f193.google.com ([209.85.210.193]:41200 "EHLO mail-pf1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727030AbfCMSkH (ORCPT ); Wed, 13 Mar 2019 14:40:07 -0400 Received: by mail-pf1-f193.google.com with SMTP id d25so1981591pfn.8 for ; Wed, 13 Mar 2019 11:40:06 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=ZKgL4zeK+z0St01hNMYKSt6dKMvw92MkjAHduvDs3M4=; b=TrX0uTyrR8JGkApkgIGcwFbP61RnpY6vKQwkP3/WLW7+611dwmic3jm/UWC51wVBzv ZxmlfoRbLDOV/svdWScPzZ/35vHi6eAsW2cpY8KPHcmb/cksQIqgn3y0kW3HqrYsAViU PARJAv80Ak4rosKlqFWfUugSTU+uhn9jnGEMIaeC64cakf8i7ChAiCsDE+0A9ZwEGCge FYEJhOYXTTU3uD2MQVw2/thiMnBJdqoCRJOKTPFBfU/2O590YceAv1YBFw8evhN+Zv2A cTfzhAI9/zmULZ+hon4mYfTi8ukHQe/72jihu//A4YZaOWgfgWZWS/peYsKluEf3cG2l xV2g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=ZKgL4zeK+z0St01hNMYKSt6dKMvw92MkjAHduvDs3M4=; b=oAsc1SEmBDmZniEEqmjZ+AdX/j5LWfik7XGbJAdTmCHp59EqDPI5F15/5oxe0ERXDR 1J+80G3anNRlAd4wWruOAH599hrnzM+2GjAbS1UvwzwnAP//qpeID3syMXXCWTxMQyjp lZyGYiWQuTIiBo+UwcNBJLbZZWyrPq3A0OlDZ60cwWds+PxJ5cVY2XewWh+kyPcIBcKl r7dl2O1zJbtY5F36FrE5WRT4RPswRkLddvgsLwiyOjHit139D2Q1neinp5PCmaWwG9FC iVFIG2wm81mtZEFb6RM5xoV4wDLp/WlocdVFfyM6F0JN7KWPOlQKm8u3YK2BileMtZhX d3VA== X-Gm-Message-State: APjAAAVfZCdcsgNjKETRJSyk5FmMaEOM6UJ9eXd+beiP0DbjefmvgMCA kWJ2nCmr+LpM0gQRirB/jZM= X-Received: by 2002:a17:902:3:: with SMTP id 3mr41784620pla.114.1552502406117; Wed, 13 Mar 2019 11:40:06 -0700 (PDT) Received: from castle.hsd1.ca.comcast.net ([2603:3024:1704:3e00::d657]) by smtp.gmail.com with ESMTPSA id i13sm15792562pgq.17.2019.03.13.11.40.04 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Wed, 13 Mar 2019 11:40:05 -0700 (PDT) From: Roman Gushchin X-Google-Original-From: Roman Gushchin To: linux-mm@kvack.org, kernel-team@fb.com Cc: linux-kernel@vger.kernel.org, Tejun Heo , Rik van Riel , Johannes Weiner , Michal Hocko , Roman Gushchin Subject: [PATCH v3 4/6] mm: release per-node memcg percpu data prematurely Date: Wed, 13 Mar 2019 11:39:51 -0700 Message-Id: <20190313183953.17854-5-guro@fb.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190313183953.17854-1-guro@fb.com> References: <20190313183953.17854-1-guro@fb.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Similar to memcg-level statistics, per-node data isn't expected to be hot after cgroup removal. Switching over to atomics and prematurely releasing percpu data helps to reduce the memory footprint of dying cgroups. Signed-off-by: Roman Gushchin Acked-by: Johannes Weiner --- include/linux/memcontrol.h | 1 + mm/memcontrol.c | 24 +++++++++++++++++++++++- 2 files changed, 24 insertions(+), 1 deletion(-) diff --git a/include/linux/memcontrol.h b/include/linux/memcontrol.h index 569337514230..f296693d102b 100644 --- a/include/linux/memcontrol.h +++ b/include/linux/memcontrol.h @@ -127,6 +127,7 @@ struct mem_cgroup_per_node { struct lruvec lruvec; struct lruvec_stat __rcu /* __percpu */ *lruvec_stat_cpu; + struct lruvec_stat __percpu *lruvec_stat_cpu_offlined; atomic_long_t lruvec_stat[NR_VM_NODE_STAT_ITEMS]; unsigned long lru_zone_size[MAX_NR_ZONES][NR_LRU_LISTS]; diff --git a/mm/memcontrol.c b/mm/memcontrol.c index efd5bc131a38..1b5fe826d6d0 100644 --- a/mm/memcontrol.c +++ b/mm/memcontrol.c @@ -4460,7 +4460,7 @@ static void free_mem_cgroup_per_node_info(struct mem_cgroup *memcg, int node) if (!pn) return; - free_percpu(pn->lruvec_stat_cpu); + WARN_ON_ONCE(pn->lruvec_stat_cpu != NULL); kfree(pn); } @@ -4616,7 +4616,17 @@ static int mem_cgroup_css_online(struct cgroup_subsys_state *css) static void percpu_rcu_free(struct rcu_head *rcu) { struct mem_cgroup *memcg = container_of(rcu, struct mem_cgroup, rcu); + int node; + + for_each_node(node) { + struct mem_cgroup_per_node *pn = memcg->nodeinfo[node]; + if (!pn) + continue; + + free_percpu(pn->lruvec_stat_cpu_offlined); + WARN_ON_ONCE(pn->lruvec_stat_cpu != NULL); + } free_percpu(memcg->vmstats_percpu_offlined); WARN_ON_ONCE(memcg->vmstats_percpu); @@ -4625,6 +4635,18 @@ static void percpu_rcu_free(struct rcu_head *rcu) static void mem_cgroup_offline_percpu(struct mem_cgroup *memcg) { + int node; + + for_each_node(node) { + struct mem_cgroup_per_node *pn = memcg->nodeinfo[node]; + + if (!pn) + continue; + + pn->lruvec_stat_cpu_offlined = (struct lruvec_stat __percpu *) + rcu_dereference(pn->lruvec_stat_cpu); + rcu_assign_pointer(pn->lruvec_stat_cpu, NULL); + } memcg->vmstats_percpu_offlined = (struct memcg_vmstats_percpu __percpu*) rcu_dereference(memcg->vmstats_percpu); rcu_assign_pointer(memcg->vmstats_percpu, NULL); -- 2.20.1