Received: by 2002:ac0:a581:0:0:0:0:0 with SMTP id m1-v6csp409248imm; Thu, 28 Jun 2018 23:18:27 -0700 (PDT) X-Google-Smtp-Source: ADUXVKKpjemdt5DORrlcROHtM6cPA194b4e/2se9l94yP/K1GifzE+juomxWFQQkzliK1h59DIYH X-Received: by 2002:a63:a70f:: with SMTP id d15-v6mr11441061pgf.168.1530253107792; Thu, 28 Jun 2018 23:18:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1530253107; cv=none; d=google.com; s=arc-20160816; b=dfwYnynd+iYQU2Y4DPjxqLe5yf/88o7jan+KFqg+L5pS2gBq9X1Hd55aKZ31I6309u kcrLH5FFlQB1ZfTxYvGxzuv2m2Uokryg/DYc+qaVKxTpnxbqaK2jlxoHtQuyQbbE/ktH dMZ3TOEZtxArlEW6bA6pRbQTmRuE4dIjeLfwoIuVBwlgVKYrUB17SxmSAJHJXkdL3W/1 ITrtk9waN49mWb9RwbbvlXAWfhZucsurUX5Dxke43qe7bTdufIL4hmlpOCGS+l9DHisg TFkniyxhdxr3xSrHE2MbdzzG2Owks4qrN3Mi8qkKHlzQazDs9PadB+ZAeihKL0LqflJP B/dg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:user-agent:in-reply-to :content-disposition:mime-version:references:reply-to:subject:cc:to :from:date:arc-authentication-results; bh=sBTBgAKwIJPdLfi69ofo4F3+6DrXENZXF529uqScQa4=; b=QAuMTvHi8NO5cczxqkIBIMYBoPxOaIZLdKU/9m99PL46sORN3ZSR0Im8Rh0JTgptu3 7LpG8SXHBUDbQx1C8vEhPgGYMqOPENtmA6wCzFS1pPkU0ajwWTSgGLVyOARxiFAZKnI5 9GykhIz+srAIrX/hL8ShpcR7gn8+EZ1lwIwdQkwAAJXZdkm6x+KinHDg3Y3DQUHdqU6U bm9p9TpU84QwsIl6Nw3eDRTq1H58c6Kn/J6Qy4wGvdagp2Ju5wcOb2bCfJqP3xbBsw0a 6p+JzpW0FOKgS3pzydsy/1h5Ct2OQlJiyvm681mUKr3WX8uosuelCeGNh8malB4xb/R+ wUJw== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=ibm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id s3-v6si8541110plb.394.2018.06.28.23.18.13; Thu, 28 Jun 2018 23:18:27 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=ibm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754769AbeF1V3G (ORCPT + 99 others); Thu, 28 Jun 2018 17:29:06 -0400 Received: from mx0a-001b2d01.pphosted.com ([148.163.156.1]:36558 "EHLO mx0a-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751750AbeF1V3F (ORCPT ); Thu, 28 Jun 2018 17:29:05 -0400 Received: from pps.filterd (m0098409.ppops.net [127.0.0.1]) by mx0a-001b2d01.pphosted.com (8.16.0.22/8.16.0.22) with SMTP id w5SLT21q109831 for ; Thu, 28 Jun 2018 17:29:05 -0400 Received: from e12.ny.us.ibm.com (e12.ny.us.ibm.com [129.33.205.202]) by mx0a-001b2d01.pphosted.com with ESMTP id 2jw62mkyja-1 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=NOT) for ; Thu, 28 Jun 2018 17:29:04 -0400 Received: from localhost by e12.ny.us.ibm.com with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted for from ; Thu, 28 Jun 2018 17:29:03 -0400 Received: from b01cxnp23032.gho.pok.ibm.com (9.57.198.27) by e12.ny.us.ibm.com (146.89.104.199) with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted; (version=TLSv1/SSLv3 cipher=AES256-GCM-SHA384 bits=256/256) Thu, 28 Jun 2018 17:28:59 -0400 Received: from b01ledav003.gho.pok.ibm.com (b01ledav003.gho.pok.ibm.com [9.57.199.108]) by b01cxnp23032.gho.pok.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id w5SLSwgE19333594 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=FAIL); Thu, 28 Jun 2018 21:28:58 GMT Received: from b01ledav003.gho.pok.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 4AE2FB2065; Thu, 28 Jun 2018 17:28:49 -0400 (EDT) Received: from b01ledav003.gho.pok.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 2CFB9B2064; Thu, 28 Jun 2018 17:28:49 -0400 (EDT) Received: from paulmck-ThinkPad-W541 (unknown [9.70.82.159]) by b01ledav003.gho.pok.ibm.com (Postfix) with ESMTP; Thu, 28 Jun 2018 17:28:49 -0400 (EDT) Received: by paulmck-ThinkPad-W541 (Postfix, from userid 1000) id B5D3116C5F24; Thu, 28 Jun 2018 14:31:05 -0700 (PDT) Date: Thu, 28 Jun 2018 14:31:05 -0700 From: "Paul E. McKenney" To: Michal Hocko Cc: Tetsuo Handa , David Rientjes , linux-mm@kvack.org, Andrew Morton , linux-kernel@vger.kernel.org Subject: Re: [PATCH] mm,oom: Bring OOM notifier callbacks to outside of OOM killer. Reply-To: paulmck@linux.vnet.ibm.com References: <1529493638-6389-1-git-send-email-penguin-kernel@I-love.SAKURA.ne.jp> <20180621073142.GA10465@dhcp22.suse.cz> <2d8c3056-1bc2-9a32-d745-ab328fd587a1@i-love.sakura.ne.jp> <20180626170345.GA3593@linux.vnet.ibm.com> <20180627072207.GB32348@dhcp22.suse.cz> <20180627143125.GW3593@linux.vnet.ibm.com> <20180628113942.GD32348@dhcp22.suse.cz> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20180628113942.GD32348@dhcp22.suse.cz> User-Agent: Mutt/1.5.21 (2010-09-15) X-TM-AS-GCONF: 00 x-cbid: 18062821-0060-0000-0000-000002840703 X-IBM-SpamModules-Scores: X-IBM-SpamModules-Versions: BY=3.00009273; HX=3.00000241; KW=3.00000007; PH=3.00000004; SC=3.00000266; SDB=6.01053715; UDB=6.00540296; IPR=6.00831637; MB=3.00021913; MTD=3.00000008; XFM=3.00000015; UTC=2018-06-28 21:29:02 X-IBM-AV-DETECTION: SAVI=unused REMOTE=unused XFE=unused x-cbparentid: 18062821-0061-0000-0000-0000459C13F1 Message-Id: <20180628213105.GP3593@linux.vnet.ibm.com> X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:,, definitions=2018-06-28_08:,, signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 priorityscore=1501 malwarescore=0 suspectscore=2 phishscore=0 bulkscore=0 spamscore=0 clxscore=1015 lowpriorityscore=0 mlxscore=0 impostorscore=0 mlxlogscore=999 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1806210000 definitions=main-1806280237 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Jun 28, 2018 at 01:39:42PM +0200, Michal Hocko wrote: > On Wed 27-06-18 07:31:25, Paul E. McKenney wrote: > > On Wed, Jun 27, 2018 at 09:22:07AM +0200, Michal Hocko wrote: > > > On Tue 26-06-18 10:03:45, Paul E. McKenney wrote: > > > [...] > > > > 3. Something else? > > > > > > How hard it would be to use a different API than oom notifiers? E.g. a > > > shrinker which just kicks all the pending callbacks if the reclaim > > > priority reaches low values (e.g. 0)? > > > > Beats me. What is a shrinker? ;-) > > This is a generich mechanism to reclaim memory that is not on standard > LRU lists. Lwn.net surely has some nice coverage (e.g. > https://lwn.net/Articles/548092/). "In addition, there is little agreement over what a call to a shrinker really means or how the called subsystem should respond." ;-) Is this set up using register_shrinker() in mm/vmscan.c? I am guessing that the many mentions of shrinker in DRM are irrelevant. If my guess is correct, the API seems a poor fit for RCU. I can produce an approximate number of RCU callbacks for ->count_objects(), but a given callback might free a lot of memory or none at all. Plus, to actually have ->scan_objects() free them before returning, I would need to use something like rcu_barrier(), which might involve longer delays than desired. Or am I missing something here? > > More seriously, could you please point me at an exemplary shrinker > > use case so I can see what is involved? > > Well, I am not really sure what is the objective of the oom notifier to > point you to the right direction. IIUC you just want to kick callbacks > to be handled sooner under a heavy memory pressure, right? How is that > achieved? Kick a worker? That is achieved by enqueuing a non-lazy callback on each CPU's callback list, but only for those CPUs having non-empty lists. This causes CPUs with lists containing only lazy callbacks to be more aggressive, in particular, it prevents such CPUs from hanging out idle for seconds at a time while they have callbacks on their lists. The enqueuing happens via an IPI to the CPU in question. Thanx, Paul