Received: by 2002:ac0:a594:0:0:0:0:0 with SMTP id m20-v6csp2950435imm; Thu, 24 May 2018 19:44:18 -0700 (PDT) X-Google-Smtp-Source: AB8JxZpXjpGSQmjmDMmoKedE9Cw0Ge1YBTiulOUGNsxoRuMYIqdMFY7DuOnccz8uXlkwVf6tctlK X-Received: by 2002:a63:740c:: with SMTP id p12-v6mr453460pgc.259.1527216257992; Thu, 24 May 2018 19:44:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527216257; cv=none; d=google.com; s=arc-20160816; b=a9fHy3E9njbqROFh6wbqNWKifkZ6CSoEQcsBhvQZJjh+V7rvnHtCYRgzPsPCRZ8xWi 0eJguBaN0z5RWYoP6jptqupfGPvzLg9ciulGRuMkn5wXiX2ibBW05iDo68kf+meadUff XULc8ob3WZLQvGH5+VJtLH6FtXGbXmc+vPjQ+9F7/MT7yuxKjy9u2qmznCm5hK3XKWSg icuh6ByKxiQM3ZGGY7wQkwJAcM1SN2GAL0QSFPFsOLQpghIKCv4L2lB+PWNzX+55ykYG v5yIIRdx9XDOunS6vg8Nif9Le6KusJoUBGhcqH805vJx+BsRFrifu94OXFBEAa0FEqeU 1BcQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :organization:references:in-reply-to:message-id:subject:cc:to:from :date:arc-authentication-results; bh=OXXCy2y0zBQURlfcwRFm7/P2HRSheQv5VjAiDjcmpLU=; b=l39EEz8j4cJXQ/ZocJFSN3erEkA/8bKn2ES7wQqmYOj4N2IYIKkNVhWlY8JpI5x1Ik f49CClZlMdM1sfx8HnQl2BhGyKYy8u505chRERWhgvCsbaSUttZ5UGxbjt9Sp3Ern3dy aEDd9NmUNLPB42z3btLMr3feX5rQD749XLXYK1satgQjRqe3qaIUH12vUcWLk8WK/TXX kLWMgnuyb6/WvAuDThXaZCcQ9nhfdqK7O+fV57oI5vCMAGWeDGU/tFo+jq3qYDsz7lAL tt1W/6e5DBpqlWP5LZwFrTWKq4wjCvsZDAhoRR1s7c75FhYOSCnPBb+zgWXEoHu6hdb0 7Wiw== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t128-v6si17674145pgc.582.2018.05.24.19.44.03; Thu, 24 May 2018 19:44:17 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S971494AbeEXUwm (ORCPT + 99 others); Thu, 24 May 2018 16:52:42 -0400 Received: from ms.lwn.net ([45.79.88.28]:51920 "EHLO ms.lwn.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S966499AbeEXUwk (ORCPT ); Thu, 24 May 2018 16:52:40 -0400 Received: from localhost.localdomain (localhost [127.0.0.1]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ms.lwn.net (Postfix) with ESMTPSA id 801B4304; Thu, 24 May 2018 20:52:30 +0000 (UTC) Date: Thu, 24 May 2018 14:52:02 -0600 From: Jonathan Corbet To: Michal Hocko Cc: LKML , , , Michal Hocko , "Darrick J. Wong" , David Sterba Subject: Re: [PATCH] doc: document scope NOFS, NOIO APIs Message-ID: <20180524145202.7d5a55c3@lwn.net> In-Reply-To: <20180524114341.1101-1-mhocko@kernel.org> References: <20180424183536.GF30619@thunk.org> <20180524114341.1101-1-mhocko@kernel.org> Organization: LWN.net X-Mailer: Claws Mail 3.15.1-dirty (GTK+ 2.24.32; x86_64-redhat-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, 24 May 2018 13:43:41 +0200 Michal Hocko wrote: > From: Michal Hocko > > Although the api is documented in the source code Ted has pointed out > that there is no mention in the core-api Documentation and there are > people looking there to find answers how to use a specific API. > > Cc: "Darrick J. Wong" > Cc: David Sterba > Requested-by: "Theodore Y. Ts'o" > Signed-off-by: Michal Hocko > --- > > Hi Johnatan, > Ted has proposed this at LSFMM and then we discussed that briefly on the > mailing list [1]. I received some useful feedback from Darrick and Dave > which has been (hopefully) integrated. Then the thing fall off my radar > rediscovering it now when doing some cleanup. Could you take the patch > please? > > [1] http://lkml.kernel.org/r/20180424183536.GF30619@thunk.org > .../core-api/gfp_mask-from-fs-io.rst | 55 +++++++++++++++++++ > 1 file changed, 55 insertions(+) > create mode 100644 Documentation/core-api/gfp_mask-from-fs-io.rst So you create the rst file, but don't add it in index.rst; that means it won't be a part of the docs build and Sphinx will complain. > diff --git a/Documentation/core-api/gfp_mask-from-fs-io.rst b/Documentation/core-api/gfp_mask-from-fs-io.rst > new file mode 100644 > index 000000000000..e8b2678e959b > --- /dev/null > +++ b/Documentation/core-api/gfp_mask-from-fs-io.rst > @@ -0,0 +1,55 @@ > +================================= > +GFP masks used from FS/IO context > +================================= > + > +:Date: Mapy, 2018 Ah...the wonderful month of Mapy....:) > +:Author: Michal Hocko > + > +Introduction > +============ > + > +Code paths in the filesystem and IO stacks must be careful when > +allocating memory to prevent recursion deadlocks caused by direct > +memory reclaim calling back into the FS or IO paths and blocking on > +already held resources (e.g. locks - most commonly those used for the > +transaction context). > + > +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 "resp." is indeed a bit terse. Even spelled out as "respectively", though, I'm not sure what the word is intended to mean here. Did you mean "or"? > +the gfp mask when calling an allocator. GFP_NOFS resp. GFP_NOIO can be Here too. > +used as shortcut. 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 a filesystem or I/O point of view" ? > +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. Wouldn't it be nice if those functions had kerneldoc comments that could be pulled in here! :) > +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) and where a lock *is* taken ? > +the corresponding restore function when the lock is 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 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. Agree with others on "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. Thanks, jon