From patchwork Tue Jul 2 08:44:07 2024
Content-Type: text/plain; charset="utf-8"
MIME-Version: 1.0
Content-Transfer-Encoding: 7bit
X-Patchwork-Submitter: Huan Yang
X-Patchwork-Id: 13719115
Return-Path:
X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on
aws-us-west-2-korg-lkml-1.web.codeaurora.org
Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17])
by smtp.lore.kernel.org (Postfix) with ESMTP id 788BCC3064D
for ; Tue, 2 Jul 2024 08:47:43 +0000 (UTC)
Received: by kanga.kvack.org (Postfix)
id F1F4F6B0088; Tue, 2 Jul 2024 04:47:42 -0400 (EDT)
Received: by kanga.kvack.org (Postfix, from userid 40)
id EA8496B0092; Tue, 2 Jul 2024 04:47:42 -0400 (EDT)
X-Delivered-To: int-list-linux-mm@kvack.org
Received: by kanga.kvack.org (Postfix, from userid 63042)
id CFB586B0093; Tue, 2 Jul 2024 04:47:42 -0400 (EDT)
X-Delivered-To: linux-mm@kvack.org
Received: from relay.hostedemail.com (smtprelay0011.hostedemail.com
[216.40.44.11])
by kanga.kvack.org (Postfix) with ESMTP id B37F76B0088
for ; Tue, 2 Jul 2024 04:47:42 -0400 (EDT)
Received: from smtpin24.hostedemail.com (a10.router.float.18 [10.200.18.1])
by unirelay03.hostedemail.com (Postfix) with ESMTP id 725A9A1BAD
for ; Tue, 2 Jul 2024 08:47:42 +0000 (UTC)
X-FDA: 82294184364.24.FABF7D9
Received: from APC01-TYZ-obe.outbound.protection.outlook.com
(mail-tyzapc01on2044.outbound.protection.outlook.com [40.107.117.44])
by imf18.hostedemail.com (Postfix) with ESMTP id 7DE081C000F
for ; Tue, 2 Jul 2024 08:47:39 +0000 (UTC)
Authentication-Results: imf18.hostedemail.com;
dkim=pass header.d=vivo.com header.s=selector2 header.b=jbDyxQC+;
spf=pass (imf18.hostedemail.com: domain of link@vivo.com designates
40.107.117.44 as permitted sender) smtp.mailfrom=link@vivo.com;
dmarc=pass (policy=quarantine) header.from=vivo.com;
arc=pass ("microsoft.com:s=arcselector9901:i=1")
ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed;
d=hostedemail.com;
s=arc-20220608; t=1719910042;
h=from:from:sender:reply-to:subject:subject:date:date:
message-id:message-id:to:to:cc:cc:mime-version:mime-version:
content-type:content-type:
content-transfer-encoding:content-transfer-encoding:
in-reply-to:in-reply-to:references:references:dkim-signature;
bh=wayXX6if5q49kSH+e7BH2GqjBW2PQyGEKDlKzSgTM/M=;
b=pKiBEfLO9iMMm/02pg/cvWG3uXOgZS/qAo72UgfFI1AS9pTuIUk2RCsDHYSXcpFD0v2NCQ
KgYmUsM8kCuYBDkgDnNNFVuPeRMzCJ/Een6CuAm7janAsMUJ+/l4RUSKkUltaGLOFzl4Qh
2VpfVerp/qsZbNfhi1x3F//DGE3k27g=
ARC-Authentication-Results: i=2;
imf18.hostedemail.com;
dkim=pass header.d=vivo.com header.s=selector2 header.b=jbDyxQC+;
spf=pass (imf18.hostedemail.com: domain of link@vivo.com designates
40.107.117.44 as permitted sender) smtp.mailfrom=link@vivo.com;
dmarc=pass (policy=quarantine) header.from=vivo.com;
arc=pass ("microsoft.com:s=arcselector9901:i=1")
ARC-Seal: i=2; s=arc-20220608; d=hostedemail.com; t=1719910042; a=rsa-sha256;
cv=pass;
b=P/Teqrfw0coG5gxoynXj9tr/Cj+TbHo4xOKwH7fOTyDJeQqg6svwGUEnQ4SFzaCCMlAAZ8
aFf9qT8Lx7ca+/S5A+BiwSnuBGV8QgknAl6T0qDmFwn/lpUytblvKDKgwwLudLhitwcXyf
iIJt0V/4lm7a8dJAJ9JPaFxkqHj2wWo=
ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none;
b=J89eKsVjJVafsKba0ue95qSrgWkHY/NfjpKu5FkaidCshw4qSUuviuh7NGddXzA6s3pqsFFohWrmDaz97YYjOPF7hai/RVyTD7r+VRsKximo/GksF5p/ZZaFaTtp7Fkj1tzJfRTckefZOcELfRGVSg5upPtbr/YQBPgUJlDpgoSt/VqqJj4FWqQFJAJpYpJlQQXSQtgaY0a9JZ2oOZbVH2LIgwL1DWeqNtkaBA5dun2j88+SIqcgV3MVI1rn7bhWGo+/h3/q4mxmIzwZDd6FRLOo7vhxLAs5jCEOG+iw+R3oIrxuNTQjQCBbt3dAd7pPk5g1b+H1/Z3IoPZtftuHbA==
ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com;
s=arcselector9901;
h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1;
bh=wayXX6if5q49kSH+e7BH2GqjBW2PQyGEKDlKzSgTM/M=;
b=GzE6U8GDjkpeKwdzvJMgMAelLrT+IiKm9e5HzN4LAzseTAM9Z1BJ5oZ+Y7h7dyzk3+zz9569X++cOtMj1OD7G/M/1YwqeeivUj9NL2oYnyHMBgtBGrLH6loniuFZiSMMz/q9A33QRo3GJ8Md6MAxS3cUlXdsEaA8o29WRtS50g321bzgjrSDC3fbehKJ5HqVJubl2fx151BqcRcyfsxJF3Nmk4Q3zKzxgho4fAEVyM8oz0zJrDUcLJVAfeFQakV2HykxiFgFNOqQvNQ65y1pguPOD9/NbgYMF5mpK64dDBwi+dM7Eon2uFMiy3gl/4ZMSDN5H5ZEwWv/nn6lUg2PTQ==
ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass
smtp.mailfrom=vivo.com; dmarc=pass action=none header.from=vivo.com;
dkim=pass header.d=vivo.com; arc=none
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=vivo.com; s=selector2;
h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck;
bh=wayXX6if5q49kSH+e7BH2GqjBW2PQyGEKDlKzSgTM/M=;
b=jbDyxQC+prZBsQ+Bb1fY+q59ALKp3VoiOI12VUaQGpE75r52B/+htLdIVeCnQNUgKqaacaF/6HhWB1I2TuHd2l5XoxiozliXXp/A643ztyUPlbhEYVs5wJRIpx9Kplx1/PM7dwQjdD/Gvpqe3DCVbY9RFCk49t1URN6/QJl0qXys7jG2CGOLXwyX9zzykd5bHbYCgNcANGWVTg/MIFONn9UHKcYASqBpfgOn+D8iYiYb5hKfNS73H42QaQIycvEF7iuGXlV/Ce4s9bkCLbXLKkZAmaP2fzOL2895x1tBmUMhC7uVG46COfWqf887BvTvv4beX6mcl5+x3WRsuoYbwQ==
Received: from PUZPR06MB5676.apcprd06.prod.outlook.com (2603:1096:301:f8::10)
by SEYPR06MB5790.apcprd06.prod.outlook.com (2603:1096:101:b9::12) with
Microsoft SMTP Server (version=TLS1_2,
cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7741.23; Tue, 2 Jul
2024 08:46:20 +0000
Received: from PUZPR06MB5676.apcprd06.prod.outlook.com
([fe80::a00b:f422:ac44:636f]) by PUZPR06MB5676.apcprd06.prod.outlook.com
([fe80::a00b:f422:ac44:636f%6]) with mapi id 15.20.7719.028; Tue, 2 Jul 2024
08:46:20 +0000
From: Huan Yang
To: Johannes Weiner ,
Michal Hocko ,
Roman Gushchin ,
Shakeel Butt ,
Muchun Song ,
Andrew Morton ,
"Matthew Wilcox (Oracle)" ,
David Hildenbrand ,
Ryan Roberts ,
Chris Li ,
Dan Schatzberg ,
Huan Yang ,
Kairui Song ,
cgroups@vger.kernel.org,
linux-mm@kvack.org,
linux-kernel@vger.kernel.org,
Christian Brauner ,
Jan Kara
Cc: opensource.kernel@vivo.com
Subject: [RFC PATCH 4/4] mm: memcg: pmc: support oom release
Date: Tue, 2 Jul 2024 16:44:07 +0800
Message-ID: <20240702084423.1717904-5-link@vivo.com>
X-Mailer: git-send-email 2.45.2
In-Reply-To: <20240702084423.1717904-1-link@vivo.com>
References: <20240702084423.1717904-1-link@vivo.com>
X-ClientProxiedBy: SG2PR01CA0148.apcprd01.prod.exchangelabs.com
(2603:1096:4:8f::28) To PUZPR06MB5676.apcprd06.prod.outlook.com
(2603:1096:301:f8::10)
MIME-Version: 1.0
X-MS-PublicTrafficType: Email
X-MS-TrafficTypeDiagnostic: PUZPR06MB5676:EE_|SEYPR06MB5790:EE_
X-MS-Office365-Filtering-Correlation-Id: 8d1a0e68-ab3e-4099-7ed0-08dc9a7371fb
X-MS-Exchange-SenderADCheck: 1
X-MS-Exchange-AntiSpam-Relay: 0
X-Microsoft-Antispam:
BCL:0;ARA:13230040|1800799024|52116014|7416014|376014|366016|921020|38350700014;
X-Microsoft-Antispam-Message-Info:
vsqpTpPI6N2WGgg0iSkF+In/Pxw7vcXP7rull1Detp3BnAezK6peCymBMaYE4BTFC6VUgTVrFrfSdpv3j3OnmhBlaItao8IymvyMiZta04sqX5geHlLQrPeiCvpfB9BZxggphQxFj0B13CyQ1IcW/6n8Rr3dmscfIRVkKfxwc1Qm/uCaQ8JAuPP1fmtxqkUW7kKqOM1rPGhanwlCUIVSKXEwu42ZIywJdRAh0CqACi7cnsMw0J72BSgDFph+0otu3EnaBqT8IAJp1bgcGzu6XgewjGax77qA7XONpmp7r1GLSQ+sc4gHSexyEMdxYmPj3fjUF6Ftjx9hBPY+YmhRnQpLIicquovcuTcMVFSwM+6i6UYQj5uxuI2FqThOeuvRXOmFRcSgel6nWqrtHyRJ+k93lm4bJj+JiLfUvQgJAuyaRETxJVoAyq987wSmodwxYIkUuL9VqRilkh7sPn8hfTIkvDa41pgjzS7TslaCVrVgzSVBfwI+t+CskecOyWG42lcABFw4l16ai+RxNS/CI/xyePVe/dByfkzw4uc0TM2CoRiGFFPMs/QYEhbxSKbR1ja+t4kbUYqWE4CXbPoAG4o+n4GEmyiNfQyVjqjZV5smuauptrRJfJzW7xIi4rYrZLLKi7ddAPKbxhA1crli10kkLViiKmQ5WRA68a7ANoGaJNl+Bdz487InmmjR7fWscyO3zsLdICv9+Wz3rTYATn3cFobDUgXlHQ93KRVUgKcD9EhRvIKmTpoU5q1QXS8C51vlN0L8kW9LO8iwVNR+b0H36stJdheAOBLr6A4g34DllIgz2LxrGLa+gCuFXXRRng3FpPIMcrkSsh/Z9NNgUP3B7d4zDgzBKrHNFOPDrVho8uAQR5cT7VBpmIiN+2otuTj3xye7GJcty7PbxYb3eOk7GeaOsJoDc9XroVRhMixenYQt+2RPiUspsRJS0DGwcc9lqCryrG/E2SfRN/DktqjhbjyPEU16mrc3HCCcZvYBnUKgYa/Rx4Z7s4Dhw4kB3fBblsQvAs6p57QxcsXQYwnjKsrhQP76LH8E4OhfuCI73EidLSOTdac5D37a7InU1rU+MHaHDGx1iencOn7C9QuDSlCCstDJKl5pSZJde33CrlyVi+BZswztEX2ymA2J+oNWBj7YaYpmtQQPd/AIxJZkW/ZL1mWq4LRwzv0lyYL0iKXLNSk1ZrW9G1TXl9Kr/VbZzmN/UbDrJeqyxi7oLTf80kuAlKGr757JnHMvNoOgdARgEh3+UJzWeTIh9IZtvYzce2SndrehSFj/QqC9rsg8ph/CnGYJ+82MRxiHJqn0czHyDVIq2Qewtukhq9+lFDhjrk+vXCo/Nhw9WmnfvrB3huyslvturCbfdYC83RR+zRrio16D5qzzcY3h0rR5+zQrWDRgDEq37NgJxjmchkF/UEvDNUOQDrvMsxCbcho=
X-Forefront-Antispam-Report:
CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:PUZPR06MB5676.apcprd06.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(1800799024)(52116014)(7416014)(376014)(366016)(921020)(38350700014);DIR:OUT;SFP:1101;
X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1
X-MS-Exchange-AntiSpam-MessageData-0:
G00yIZH0KEXv5OXfIs8l6NEO6NXL/A61iR75yv9JrQ4l9AbLuHyffUj7a5J3d2gY4FFKiG50arGFekXXHwmcwiP1TVEfJ5+X8k8JaqIJxEpkrn+2MQnmtIKbEiG26ITnRSNlhBjhggQHSl+hdj8WUR7tKjC2qAx/m7RoM1rsrs8KFH86Vb0t6tdSk7W+AAowq/LfC/ktSMvcNnKQa1+L+qUsM1iqyXCII1obprL072SPiPYSARlvA6iLrLKNYhEMSbOUzT7wA5DcqCLga3rSXvefwjQeowPJQbbmdt8SnEk9S6EdbcKT0AzGya17bOURMeoo7WaeYAWOA6UCBCKpDXZhY0fToSzqbwqO1hSbSxF4paYKYxZ8Ys3QguAz+K2dBqqC7OrC8DujIUwT4Y0m485VLXTvVtqH3YQ8f7gCa2QAN0Nk0jtHCnZw+pqUdnISEoAp2Kocpz32oDfyFPBNJvPfCZfvh5iIzSO2U15w5fgcPMIndPcVppPhD1a5625W2n5hn/uaKN02jA+97hvrCttA5QoUft2OyxyAwND0cOPUwSyrf754LWRHAvGz6vswU0/eqmeFpbRpmEWcbqX/vLB4xAHjOQCy7dz9OMMDD+hh4RVeMk++XHoB7pk4U+bo0ud7e0ktqiGtK0FCTYKbZYg/a3XhHMypbn8xtHyJZaE366zSpIc9t9o8o9n0nL+kjzfLxx1ILNwQ6oLoBgV8WwmcppeJZmriG45r3+UL8iPsJxqcmXDDKYCVDh6MrgpnNMpvNRs9clGlZWRTuJrHlPlARJWIOYaoQAuhMZGkCAHQaaKGhinKXekj2++hFYrm3lq1ayAu2iEbNgjprj9jYb1PwPEUDjWU4YOex29tH1k5T+/fyLvLBaPvyuCsbmUy3zwJZ7cy9x2f+pODrkiCD3PIntCpSMwihFOytiOuBnW2aZARey2Onmy7AfZnoRPliiFz6cuyjlg1dePCg4pvROMjZulm9WvB69IaVNruS6JhxEe179k0jrg2KJwp/Jv4m+Ucu+OYTD4v4PeRJCUMb8yeqU5ZZVCxDGexGNRxry9ris3Cd2GlkRPXzJKL43BgbsXOHsHj8IFLskUiCy/Xu5GkA3WX4kHKSDb4sdCnMvUEFSh6DGqI74aqL8ZM4q5khl66VaGGiKE5yNzpD+kznrzOnrIOFOkGeJVpAMRFVfj6DXfD/AkVvDq2oRY8DXP5jkks9u8pdmy16PSnd9KIpuNAzG7TpJrdhBt1BiVzXRrqde6vaDcRgo9/M8QkXYsDXU2x9cdvzCUDUr1nJyEDj2tq7h54ffeXv7asqoP7gSJz+YLRsGUFyKVSVqpw6ydEAttdptNFTxm3j86kN63QsiqTD9KKSP/X8DlDH39+/lAdnGHAv7HtB8HkfFSOsiOX4Z/AU3lTUzLMKjQl18ZSuWiRGhPRgoQHjkHcdVXzhyy0rTAjCzuthXBXTgkGEtKfm4gH/A+AyZpT2qAqUnCDuaNCB6ZB6w8PSH2DZuhMK75cmRRK3CtpfXHVNBG3tmeP3Ns9pYY3m6vE6hKCBO8ZqBDEqdwA+zWHWkPl98DkrvkqkTvMPWBgApWyp+O0YKGP
X-OriginatorOrg: vivo.com
X-MS-Exchange-CrossTenant-Network-Message-Id:
8d1a0e68-ab3e-4099-7ed0-08dc9a7371fb
X-MS-Exchange-CrossTenant-AuthSource: PUZPR06MB5676.apcprd06.prod.outlook.com
X-MS-Exchange-CrossTenant-AuthAs: Internal
X-MS-Exchange-CrossTenant-OriginalArrivalTime: 02 Jul 2024 08:46:20.5457
(UTC)
X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted
X-MS-Exchange-CrossTenant-Id: 923e42dc-48d5-4cbe-b582-1a797a6412ed
X-MS-Exchange-CrossTenant-MailboxType: HOSTED
X-MS-Exchange-CrossTenant-UserPrincipalName:
NzEupW0V4BOAb11XvdtEl5741crWW/za4brGf8wfDzJOF1VhuEWE95CWnRRZ0d9S8GmZWXDn1bEoyugO4NVe2g==
X-MS-Exchange-Transport-CrossTenantHeadersStamped: SEYPR06MB5790
X-Stat-Signature: yzdgc6s8zz3dykczoukx8hrayk6xss99
X-Rspam-User:
X-Rspamd-Queue-Id: 7DE081C000F
X-Rspamd-Server: rspam02
X-HE-Tag: 1719910059-145365
X-HE-Meta:
U2FsdGVkX1/cW7bWZkUd+7OMQsVQgw8KV2pmJxv3tKHQf93yLZ3egVr/spQPDgmiCvGghhdT0qCb0yjR4JBtqfnvdJ1RKg9+kIZGxfTgXCSLl8wERsiiGDZzIdJYpetLypuJIo4gCdoHgnKFAJlVwxPQxrkMnLe/aJScI94+xz5mgAp//5tndHB1q7CyLG9BMpNKezISxOl/v54ClxMQhc51r6oqeGgsxOuHbB0QwfH5i7m75phacyzxr7c+24N8WFJDv2rmCgJ7YtxFfuWxnW7HJCzVOTu02ATYudBE224jh+CESHeMdeQMbxljWk/ftFncl/iCzaZQ1YMmyGA4y9ovq59IbFoaWmIhG7h7ZjmLOapPWY3hbmNrsgvzvJm77uGSsEKOYFB1nrr0cD8wBs4A0snoulo5z7tVfAgVX1Q62Feq+Npxc07vjaUuv5DPoRry5YaF/OdSmKR+fmN2OaWnzRgI45qouJViNmhrcD/7sIpkBLcQrW0kLaj8GLJZrhn+voKYx16XIUzbx7FsWnMnEEpLPxL3yrCNEE9gBFRpuG/GL1NR22rIE6OS7OZboI+efHR6WfuFM9MP+IpualpRXcdE+ZZ0dfO/xBGdITAkGDov500zuZH+hI/iPHjRWjaCb5d4IhO/0WzUXO/4YOLaptHdFi3oGVAC5G3X1zQ4uKhZhxOHYntaDbB3a3vUP8h8IUsVtd1PgYAshAo7OwNqLIFF2ESOl7Gl8Ocobd5GBZ3/c1rlZTY32QUFDR06WQlILMXtCNGchwO8oPoSOq51/A/vrgBbJzZHb5j+Gv4vU8SJ46JcNUwN9Wy/NdW9AF3Mxyb44bmIE4LEwjLWYfouIyAGSZU/Vxem/BKTv3mCICdvq6vHTVn/eeLhpUOiXXMfyYrm+decwa5A3F40YxRCrSEk6Dyly3YtKTwrZGqjDbW3EGZrFFiQV75bBbh/zMmvoIB8pxFEBi/8hyc
dIS2ElgV
D/+MN4q/A6S9VyUesnVspnU9xA3/fad5qv1kXsppdUxMQNbHcPHmYaLBpOT6MTwwZjj/fX4OkDmb+CcOi4TzkUdKBvvSFyk/mT40PZselrqsj0nmIixyLJL1jcusr9uXjWc0bvckJF3XI2FOtEDvNhDpt7RJtS/qHf2qDNKvRrLBKgl/UKPtUzkVVqt/Kdm2bYbcNWR502aZqImEdE4TgY+MJ7Mg2osSTIMCOuFejwzlgDL0N4OEiE5QFMytTeawdmqb7upFkjzX95AZ8icRncwL1UVa7pREKdS8F5Vm/yLZhRDkAJK5aGlos9EoEvgtMfRFDMXuaU/oNTBhE3pYfgl8vZJxR62sE7HasGBRyUeopULH7SUYoR2hm9g==
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:
List-Subscribe:
List-Unsubscribe:
This patch let each enabled pmc's memcg register a oom listener,
so if oom will trigger, release all hold pages.
Signed-off-by: Huan Yang
---
include/linux/mmzone.h | 3 +++
mm/memcontrol.c | 31 +++++++++++++++++++++++++++++++
2 files changed, 34 insertions(+)
diff --git a/include/linux/mmzone.h b/include/linux/mmzone.h
index b56dd462232b..640a9cf51791 100644
--- a/include/linux/mmzone.h
+++ b/include/linux/mmzone.h
@@ -622,6 +622,9 @@ struct mem_cgroup_per_node_cache {
unsigned int reaper_wait;
struct delayed_work reaper_work;
+ /* listen oom event, release hold cache */
+ struct notifier_block oom_nb;
+
/* max number to hold page, unit page, default 100MB */
#define DEFAULT_PMC_HOLD_LIMIX ((100 << 20) >> PAGE_SHIFT)
unsigned int hold_limit;
diff --git a/mm/memcontrol.c b/mm/memcontrol.c
index ae6917de91cc..3dfb2a17c1fd 100644
--- a/mm/memcontrol.c
+++ b/mm/memcontrol.c
@@ -7101,6 +7101,33 @@ static ssize_t memory_reclaim(struct kernfs_open_file *of, char *buf,
return nbytes;
}
+/**
+ * This function listen to oom event, if oom will trigger, check and release
+ * all holded pages.
+ */
+static int pmc_oom_notify(struct notifier_block *self,
+ unsigned long notused, void *nfreed)
+{
+ struct mem_cgroup_per_node_cache *node_cachep =
+ container_of(self, struct mem_cgroup_per_node_cache, oom_nb);
+ struct mem_cgroup *memcg = node_cachep->memcg;
+
+ unsigned long *nf = (unsigned long *)nfreed;
+
+ rcu_read_lock();
+ if (!css_tryget(&memcg->css)) {
+ rcu_read_unlock();
+ return NOTIFY_STOP;
+ }
+ rcu_read_unlock();
+
+ nf += mem_cgroup_release_cache(node_cachep);
+
+ css_put(&memcg->css);
+
+ return NOTIFY_OK;
+}
+
/**
* This function use to reaper all cache pages by cycling scan.
* The scan interval time depends on @reaper_wait which can set by `keys` nest
@@ -7176,6 +7203,9 @@ static int __enable_mem_cgroup_cache(struct mem_cgroup *memcg)
p->allow_watermark = DEFAULT_PMC_GAP_WATERMARK;
p->reaper_wait = DEFAULT_PMC_REAPER_TIME;
+ p->oom_nb.notifier_call = pmc_oom_notify;
+ register_oom_notifier(&p->oom_nb);
+
atomic_inc(&pmc_nr_enabled);
INIT_DELAYED_WORK(&p->reaper_work, pmc_reaper);
@@ -7222,6 +7252,7 @@ static int __disable_mem_cgroup_cache(struct mem_cgroup *memcg)
p = nodeinfo->cachep;
+ unregister_oom_notifier(&p->oom_nb);
cancel_delayed_work_sync(&p->reaper_work);
mem_cgroup_release_cache(p);