Received: by 10.192.165.148 with SMTP id m20csp101624imm; Wed, 9 May 2018 09:25:40 -0700 (PDT) X-Google-Smtp-Source: AB8JxZo1ErJpBpQ5KgXPZ27BJFYZDj3+fqwfED8jlVwiIs78fqWAa4gPSIBZogqJj7MBpNdqeH14 X-Received: by 2002:a17:902:82c3:: with SMTP id u3-v6mr45780304plz.83.1525883140874; Wed, 09 May 2018 09:25:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1525883140; cv=none; d=google.com; s=arc-20160816; b=075kxK9q3EWf9C9wyrFLkgL/sSpmy1+b+67Y6lA4J+0qdU7RIknrd7vrXwWF4mkS5z FBEbIzqIWm7j+zoxgRqf2eRek3Be+GAaRNdHOi7i0cwB8lcAsLa3r1g3x18rDA0x5Pow m+yldUbB/E5bV9TlqWw/68IX70JMBVZtTg5VJ6wKvUXEOULzK6Xc4UISh10GAaD7wi5x U8ZCvA8USioPZGA6NjA+e4gUWFjFWV7Aq86SdcIS773OewsFxZM2acO7nVVMCNdkJyiZ YrhxWlvPCnxFMggjonHxI6hZnbsvt75160myCCRHN6KR1yzwuqMpwW0DxnqKjINTcIEM D56g== 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:subject:cc:to:from:date :arc-authentication-results; bh=Jqv5RpczssSqsgz+tjC6v4murV9ahSgdfBMtI2uYCcU=; b=K3+slt3qg8ZGlizxvvuf+3Z5QkkepctiMZkHc5rAdLyvCwmFOubthBaMPco3mBkzFq NS7YZoByXlCD5A97GCesr/HOPgp9M7YHzjpmKIEVns5hGUSVHsMqXG8knjk/GXeXTsI0 eKlE8CzHOR2FBrE2K3BJaVoeopWoxYEsT9bEKGHUCVDIbKWd+GV+DziKj9s6O8BzzQqc SKXgOfCsCm5aPmBCYQa2HRo1ywsF7QzPrIJGo9h9WsZipltas5HSL2Y6FGP/W1wLRtLQ 2Jg/6melWYfr4MoezWu1mJv2GnNneONbczucIj9DCtwtMPqZLyhv7l2OTr28cJ3mZv50 WnrA== 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 t3-v6si17072121ply.192.2018.05.09.09.25.25; Wed, 09 May 2018 09:25:40 -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 S965489AbeEIQZJ (ORCPT + 99 others); Wed, 9 May 2018 12:25:09 -0400 Received: from mx0a-001b2d01.pphosted.com ([148.163.156.1]:46146 "EHLO mx0a-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S965034AbeEIQZI (ORCPT ); Wed, 9 May 2018 12:25:08 -0400 Received: from pps.filterd (m0098393.ppops.net [127.0.0.1]) by mx0a-001b2d01.pphosted.com (8.16.0.22/8.16.0.22) with SMTP id w49GM7WH033073 for ; Wed, 9 May 2018 12:25:07 -0400 Received: from e06smtp12.uk.ibm.com (e06smtp12.uk.ibm.com [195.75.94.108]) by mx0a-001b2d01.pphosted.com with ESMTP id 2hv38tvhj9-1 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=NOT) for ; Wed, 09 May 2018 12:25:07 -0400 Received: from localhost by e06smtp12.uk.ibm.com with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted for from ; Wed, 9 May 2018 17:25:04 +0100 Received: from b06cxnps3075.portsmouth.uk.ibm.com (9.149.109.195) by e06smtp12.uk.ibm.com (192.168.101.142) with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted; Wed, 9 May 2018 17:24:56 +0100 Received: from d06av26.portsmouth.uk.ibm.com (d06av26.portsmouth.uk.ibm.com [9.149.105.62]) by b06cxnps3075.portsmouth.uk.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id w49GOuf765470696; Wed, 9 May 2018 16:24:56 GMT Received: from d06av26.portsmouth.uk.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 948D3AE045; Wed, 9 May 2018 17:14:23 +0100 (BST) Received: from d06av26.portsmouth.uk.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 2E1D5AE051; Wed, 9 May 2018 17:14:21 +0100 (BST) Received: from rapoport-lnx (unknown [9.148.206.252]) by d06av26.portsmouth.uk.ibm.com (Postfix) with ESMTPS; Wed, 9 May 2018 17:14:21 +0100 (BST) Date: Wed, 9 May 2018 19:24:51 +0300 From: Mike Rapoport To: "Darrick J. Wong" Cc: Michal Hocko , "Theodore Y. Ts'o" , LKML , Artem Bityutskiy , Richard Weinberger , David Woodhouse , Brian Norris , Boris Brezillon , Marek Vasut , Cyrille Pitchen , Andreas Dilger , Steven Whitehouse , Bob Peterson , Trond Myklebust , Anna Schumaker , Adrian Hunter , Philippe Ombredanne , Kate Stewart , Mikulas Patocka , linux-mtd@lists.infradead.org, linux-ext4@vger.kernel.org, cluster-devel@redhat.com, linux-nfs@vger.kernel.org, linux-mm@kvack.org Subject: Re: vmalloc with GFP_NOFS References: <20180424162712.GL17484@dhcp22.suse.cz> <20180424183536.GF30619@thunk.org> <20180424192542.GS17484@dhcp22.suse.cz> <20180509134222.GU32366@dhcp22.suse.cz> <20180509151351.GA4111@magnolia> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20180509151351.GA4111@magnolia> User-Agent: Mutt/1.5.24 (2015-08-30) X-TM-AS-GCONF: 00 x-cbid: 18050916-0008-0000-0000-000004F4D8C0 X-IBM-AV-DETECTION: SAVI=unused REMOTE=unused XFE=unused x-cbparentid: 18050916-0009-0000-0000-00001E892248 Message-Id: <20180509162451.GA5303@rapoport-lnx> X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:,, definitions=2018-05-09_06:,, signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 priorityscore=1501 malwarescore=0 suspectscore=0 phishscore=0 bulkscore=0 spamscore=0 clxscore=1011 lowpriorityscore=0 impostorscore=0 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1709140000 definitions=main-1805090153 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, May 09, 2018 at 08:13:51AM -0700, Darrick J. Wong wrote: > On Wed, May 09, 2018 at 03:42:22PM +0200, Michal Hocko wrote: > > On Tue 24-04-18 13:25:42, Michal Hocko wrote: > > [...] > > > > As a suggestion, could you take > > > > documentation about how to convert to the memalloc_nofs_{save,restore} > > > > scope api (which I think you've written about e-mails at length > > > > before), and put that into a file in Documentation/core-api? > > > > > > I can. > > > > Does something like the below sound reasonable/helpful? > > --- > > ================================= > > GFP masks used from FS/IO context > > ================================= > > > > :Date: Mapy, 2018 > > :Author: Michal Hocko > > > > Introduction > > ============ > > > > FS resp. IO submitting code paths have to be careful when allocating > > Not sure what 'FS resp. IO' means here -- 'FS and IO' ? > > (Or is this one of those things where this looks like plain English text > but in reality it's some sort of markup that I'm not so familiar with?) > > Confused because I've seen 'resp.' used as shorthand for > 'responsible'... > > > memory to prevent from potential recursion deadlocks caused by direct > > memory reclaim calling back into the FS/IO path and block on already > > held resources (e.g. locks). Traditional way to avoid this problem > > 'The traditional way to avoid this deadlock problem...' > > > is to clear __GFP_FS resp. __GFP_IO (note the later implies clearing > > the first as well) in the gfp mask when calling an allocator. GFP_NOFS > > resp. GFP_NOIO can be used as shortcut. > > > > This has been the traditional way to avoid deadlocks since ages. It > > I think this sentence is a little redundant with the previous sentence, > you could chop it out and join this paragraph to the one before it. > > > turned out though that above approach has led to abuses when the restricted > > gfp mask is used "just in case" without a deeper consideration which leads > > to problems because an excessive use of GFP_NOFS/GFP_NOIO can lead to > > memory over-reclaim or other memory reclaim issues. > > > > New API > > ======= > > > > Since 4.12 we do have a generic scope API for both NOFS and NOIO context > > ``memalloc_nofs_save``, ``memalloc_nofs_restore`` resp. ``memalloc_noio_save``, > > ``memalloc_noio_restore`` which allow to mark a scope to be a critical > > section from the memory reclaim recursion into FS/IO POV. Any allocation > > from that scope will inherently drop __GFP_FS resp. __GFP_IO from the given > > mask so no memory allocation can recurse back in the FS/IO. > > > > FS/IO code then simply calls the appropriate save function right at > > the layer where a lock taken from the reclaim context (e.g. shrinker) > > is taken and the corresponding restore function when the lock is Seems like the second "is taken" got there by mistake > > released. All that ideally along with an explanation what is the reclaim > > context for easier maintenance. > > > > What about __vmalloc(GFP_NOFS) > > ============================== > > > > vmalloc doesn't support GFP_NOFS semantic because there are hardcoded > > GFP_KERNEL allocations deep inside the allocator which are quit non-trivial > > ...which are quite non-trivial... > > > to fix up. That means that calling ``vmalloc`` with GFP_NOFS/GFP_NOIO is > > almost always a bug. The good news is that the NOFS/NOIO semantic can be > > achieved by the scope api. > > > > In the ideal world, upper layers should already mark dangerous contexts > > and so no special care is required and vmalloc should be called without > > any problems. Sometimes if the context is not really clear or there are > > layering violations then the recommended way around that is to wrap ``vmalloc`` > > by the scope API with a comment explaining the problem. > > Otherwise looks ok to me based on my understanding of how all this is > supposed to work... > > Reviewed-by: Darrick J. Wong > > --D > > > -- > > Michal Hocko > > SUSE Labs > -- Sincerely yours, Mike.