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=-16.8 required=3.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER,INCLUDES_PATCH, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED,USER_AGENT_GIT autolearn=ham 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 8807AC433E0 for ; Tue, 2 Mar 2021 01:36:51 +0000 (UTC) Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by mail.kernel.org (Postfix) with ESMTP id A793660C40 for ; Tue, 2 Mar 2021 01:36:50 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org A793660C40 Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=huawei.com Authentication-Results: mail.kernel.org; spf=pass smtp.mailfrom=owner-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix) id 021D46B00D7; Mon, 1 Mar 2021 20:36:50 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id F16B86B00D8; Mon, 1 Mar 2021 20:36:49 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id E2D656B00D9; Mon, 1 Mar 2021 20:36:49 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from forelay.hostedemail.com (smtprelay0078.hostedemail.com [216.40.44.78]) by kanga.kvack.org (Postfix) with ESMTP id CDE186B00D7 for ; Mon, 1 Mar 2021 20:36:49 -0500 (EST) Received: from smtpin17.hostedemail.com (10.5.19.251.rfc1918.com [10.5.19.251]) by forelay01.hostedemail.com (Postfix) with ESMTP id 8BABC180AD83B for ; Tue, 2 Mar 2021 01:36:49 +0000 (UTC) X-FDA: 77873220138.17.3894FDD Received: from szxga05-in.huawei.com (szxga05-in.huawei.com [45.249.212.191]) by imf17.hostedemail.com (Postfix) with ESMTP id 45C184000311 for ; Tue, 2 Mar 2021 01:36:48 +0000 (UTC) Received: from DGGEMS411-HUB.china.huawei.com (unknown [172.30.72.58]) by szxga05-in.huawei.com (SkyGuard) with ESMTP id 4DqKSS1k6szjVBC; Tue, 2 Mar 2021 09:35:04 +0800 (CST) Received: from huawei.com (10.175.112.208) by DGGEMS411-HUB.china.huawei.com (10.3.19.211) with Microsoft SMTP Server id 14.3.498.0; Tue, 2 Mar 2021 09:36:37 +0800 From: Zhou Guanghui To: , CC: , , , , , , Subject: [PATCH] mm/memcg: set memcg when split pages Date: Tue, 2 Mar 2021 01:34:51 +0000 Message-ID: <20210302013451.118701-1-zhouguanghui1@huawei.com> X-Mailer: git-send-email 2.25.0 MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.175.112.208] X-CFilter-Loop: Reflected X-Rspamd-Server: rspam04 X-Rspamd-Queue-Id: 45C184000311 X-Stat-Signature: sox9pog9na49it9f6y78b1abt4sijfck Received-SPF: none (huawei.com>: No applicable sender policy available) receiver=imf17; identity=mailfrom; envelope-from=""; helo=szxga05-in.huawei.com; client-ip=45.249.212.191 X-HE-DKIM-Result: none/none X-HE-Tag: 1614649008-792288 Content-Transfer-Encoding: quoted-printable 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: When split page, the memory cgroup info recorded in first page is not copied to tail pages. In this case, when the tail pages are freed, the uncharge operation is not performed. As a result, the usage of this memcg keeps increasing, and the OOM may occur. So, the copying of first page's memory cgroup info to tail pages is needed when split page. Signed-off-by: Zhou Guanghui --- include/linux/memcontrol.h | 10 ++++++++++ mm/page_alloc.c | 4 +++- 2 files changed, 13 insertions(+), 1 deletion(-) diff --git a/include/linux/memcontrol.h b/include/linux/memcontrol.h index e6dc793d587d..c7e2b4421dc1 100644 --- a/include/linux/memcontrol.h +++ b/include/linux/memcontrol.h @@ -867,6 +867,12 @@ void mem_cgroup_print_oom_group(struct mem_cgroup *m= emcg); extern bool cgroup_memory_noswap; #endif =20 +static inline void copy_page_memcg(struct page *dst, struct page *src) +{ + if (src->memcg_data) + dst->memcg_data =3D src->memcg_data; +} + struct mem_cgroup *lock_page_memcg(struct page *page); void __unlock_page_memcg(struct mem_cgroup *memcg); void unlock_page_memcg(struct page *page); @@ -1291,6 +1297,10 @@ mem_cgroup_print_oom_meminfo(struct mem_cgroup *me= mcg) { } =20 +static inline void copy_page_memcg(struct page *dst, struct page *src) +{ +} + static inline struct mem_cgroup *lock_page_memcg(struct page *page) { return NULL; diff --git a/mm/page_alloc.c b/mm/page_alloc.c index 3e4b29ee2b1e..ee0a63dc1c9b 100644 --- a/mm/page_alloc.c +++ b/mm/page_alloc.c @@ -3307,8 +3307,10 @@ void split_page(struct page *page, unsigned int or= der) VM_BUG_ON_PAGE(PageCompound(page), page); VM_BUG_ON_PAGE(!page_count(page), page); =20 - for (i =3D 1; i < (1 << order); i++) + for (i =3D 1; i < (1 << order); i++) { set_page_refcounted(page + i); + copy_page_memcg(page + i, page); + } split_page_owner(page, 1 << order); } EXPORT_SYMBOL_GPL(split_page); --=20 2.25.0