Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp3097538pxb; Fri, 12 Feb 2021 09:05:50 -0800 (PST) X-Google-Smtp-Source: ABdhPJz/BVuIkMeIBVGkIIlSDf0VLoNRbpVUbjx13Sr3hz4r+COz4JHsCEEBmyzEg7xTrpH5P2xg X-Received: by 2002:a17:906:378d:: with SMTP id n13mr3832337ejc.386.1613149550121; Fri, 12 Feb 2021 09:05:50 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1613149550; cv=none; d=google.com; s=arc-20160816; b=eUfXuzGp/lPrfKzGjUuRUr1YQHzSwPmsL/xaHeGUONdlECbI53b3sntFYs97/2pzD6 laLc6FTtXk934qjjbsdEx9ba2UeB9bc/edpboRHXOAmOjyLg4GxIH7vvAZI2HIC3/Bo/ qz2t8RQlGkDiVuWm76RZHi7XQppH/z+Af0Eeu37Xyil8azFHaBh/0oM29JvNiEjABUuC F30nT13rml64T1kxx+jQXS+jiIC6zUtNgCRqG4D7/RXxdhkwFuTmXLXqykMgAVyQy2aY 0FDOT26k8Cq/XjrqXw1PNE1zT3tpMCr2REE420UqJlh8N4P3sVVUFljFQTPfwnhqTgiI t8UQ== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=bcYt0NSihifXZf17H55Cj5Hl2GUjQyX5Z/whSKEEhxI=; b=Gbe3bD0Nku8opnmkBw0JTxMiaaG+/dmsZiIfsN2DHrc0hQygkXYKM13CW/Lz4DE12i oXHuWLHOAFz+ghRj09Rq2Oyemn/A1+oXT4/rnGwbHSGLnRcwK/5VFSlr/lxPDeXk5hJC qNiu4VAoX+XiXk9h0Jt6hymnUkNn7U1QuB6ERV3pUa2nSyQjnaPZiud3tRUux8s4RCwa S7rrxMjkjx7MfqUQoJB123MQtDLWbR1zFyEzamMrlNUlgTOFJvCmXaJQiHGoIFApuWn5 UKsUCziqZIhJvvBvQsEfHTH7khvUfvAz6uWaQhl0K82ensl0HPomBwk/gvOqHq2L1dUw DXIw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@bytedance-com.20150623.gappssmtp.com header.s=20150623 header.b=QXdiNtz4; 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=bytedance.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id hs28si3355377ejc.141.2021.02.12.09.05.25; Fri, 12 Feb 2021 09:05:50 -0800 (PST) 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; dkim=pass header.i=@bytedance-com.20150623.gappssmtp.com header.s=20150623 header.b=QXdiNtz4; 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=bytedance.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229745AbhBLRDL (ORCPT + 99 others); Fri, 12 Feb 2021 12:03:11 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42552 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229493AbhBLRDB (ORCPT ); Fri, 12 Feb 2021 12:03:01 -0500 Received: from mail-pl1-x62d.google.com (mail-pl1-x62d.google.com [IPv6:2607:f8b0:4864:20::62d]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 18B38C061786 for ; Fri, 12 Feb 2021 09:02:21 -0800 (PST) Received: by mail-pl1-x62d.google.com with SMTP id d15so175111plh.4 for ; Fri, 12 Feb 2021 09:02:21 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bytedance-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=bcYt0NSihifXZf17H55Cj5Hl2GUjQyX5Z/whSKEEhxI=; b=QXdiNtz4icRE9wYOkzwNj/MEYjknOPfl+3qraA/tVpTL1yVUQ1uW/Egvq3zevZw11m 20DnFlwvQipf18yyHzSbhvGpWQ214vwvIYstobFglcVWyBKXAYFVQKqdebGoExkRRSK5 eiQft2Jyww09TKCwpm9fRe6tkSks1kczSXEdcv/laOSq5Cy74ohKIYxLVjPANARtpaLa liZ+acD0FILIz+lrXrA0/L9tZrDVhVAsNAGcQONgLpjgPGdqpzEP9NdCgVeVK6fjDxQo CXm7xNS6alE/sydQVkPcpDYcXQZrJZE64mOIICrRUaLwpDpPS5NX11mhQxdktolhNWPw vO4w== 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=bcYt0NSihifXZf17H55Cj5Hl2GUjQyX5Z/whSKEEhxI=; b=CanxP993SxcC/jhtbkYOelxg2F+JqKvUSKk45XxIqXhdjinHtvLUy2eTUY1d6Ow3TV BeHy2k9R1kjt+X0rZk4Ggeit4XTeyjpz/OQSQRXT1Is3GpmnYtIr48N2sZAsWOzhiR36 EqieQOCpdaakUuzFnPg8K0gzT8zw0aK5/+MEzJ3ykJIkZbBr4oxivzlVLMRT3JbI2lx+ D7prQKbDHcYCc2CK6krK9klWNfIt2CZ9z8yk7iKuQWTEuWeBirjah0cizR5qeTKyPNca co9vH2v2IcIusJpeWgKlQvrK2P8aaFAPIECBFZgfZnkk9DzWSvIoiAtnyUMxAF217k7B uhbg== X-Gm-Message-State: AOAM531Df0vjFvvTaKNbGQTUb98Mz1demqxOowRtC+v73LS94Fq8adOo mXd6TUrh0EcYk2rJeCUuhDnzlw== X-Received: by 2002:a17:903:31c4:b029:e1:8840:8ab9 with SMTP id v4-20020a17090331c4b02900e188408ab9mr3441164ple.70.1613149340708; Fri, 12 Feb 2021 09:02:20 -0800 (PST) Received: from localhost.bytedance.net ([139.177.225.254]) by smtp.gmail.com with ESMTPSA id e21sm9317815pgv.74.2021.02.12.09.02.16 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Fri, 12 Feb 2021 09:02:19 -0800 (PST) From: Muchun Song To: hannes@cmpxchg.org, mhocko@kernel.org, vdavydov.dev@gmail.com, akpm@linux-foundation.org Cc: cgroups@vger.kernel.org, linux-mm@kvack.org, linux-kernel@vger.kernel.org, Muchun Song Subject: [PATCH 2/4] mm: memcontrol: add missing memcg_oom_recover() when uncharge slab page Date: Sat, 13 Feb 2021 01:01:57 +0800 Message-Id: <20210212170159.32153-2-songmuchun@bytedance.com> X-Mailer: git-send-email 2.21.0 (Apple Git-122) In-Reply-To: <20210212170159.32153-1-songmuchun@bytedance.com> References: <20210212170159.32153-1-songmuchun@bytedance.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org When we uncharge a page, we wake up oom victims when the memcg oom handling is outsourced to the userspace. The uncharge_batch do that for normal and kmem pages but not slab pages. It is likely an omission. So add the missing memcg_oom_recover() to __memcg_kmem_uncharge(). And the function of memory.oom_control is only suitable for cgroup v1. So guard this test (memcg->under_oom) by the cgroup_subsys_on_dfl(memory_cgrp_subsys). Signed-off-by: Muchun Song --- mm/memcontrol.c | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) diff --git a/mm/memcontrol.c b/mm/memcontrol.c index 7afca9677693..a3f26522765a 100644 --- a/mm/memcontrol.c +++ b/mm/memcontrol.c @@ -3126,8 +3126,10 @@ static int __memcg_kmem_charge(struct mem_cgroup *memcg, gfp_t gfp, */ static void __memcg_kmem_uncharge(struct mem_cgroup *memcg, unsigned int nr_pages) { - if (!cgroup_subsys_on_dfl(memory_cgrp_subsys)) + if (!cgroup_subsys_on_dfl(memory_cgrp_subsys)) { page_counter_uncharge(&memcg->kmem, nr_pages); + memcg_oom_recover(memcg); + } refill_stock(memcg, nr_pages); } @@ -6806,11 +6808,15 @@ static void uncharge_batch(const struct uncharge_gather *ug) if (!mem_cgroup_is_root(ug->memcg)) { page_counter_uncharge(&ug->memcg->memory, ug->nr_pages); - if (do_memsw_account()) - page_counter_uncharge(&ug->memcg->memsw, ug->nr_pages); - if (!cgroup_subsys_on_dfl(memory_cgrp_subsys) && ug->nr_kmem) - page_counter_uncharge(&ug->memcg->kmem, ug->nr_kmem); - memcg_oom_recover(ug->memcg); + if (!cgroup_subsys_on_dfl(memory_cgrp_subsys)) { + if (!cgroup_memory_noswap) + page_counter_uncharge(&ug->memcg->memsw, + ug->nr_pages); + if (ug->nr_kmem) + page_counter_uncharge(&ug->memcg->kmem, + ug->nr_kmem); + memcg_oom_recover(ug->memcg); + } } local_irq_save(flags); -- 2.11.0