Received: by 10.192.165.148 with SMTP id m20csp361761imm; Wed, 9 May 2018 14:05:20 -0700 (PDT) X-Google-Smtp-Source: AB8JxZooCU1xHoUE9hEojgQ+sZlhNgQeysejYjBhXKIeanQ0h4h1H8NWYUm629P450cOveuS9Jxe X-Received: by 2002:a65:6585:: with SMTP id u5-v6mr36465875pgv.396.1525899920524; Wed, 09 May 2018 14:05:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1525899920; cv=none; d=google.com; s=arc-20160816; b=EdD5jbCbsRzo0DkXsgzgoVEXf3+H6gYrC29sxJenEOLBfGIOOSNIZ0Tqxz/6Jdw2Bt WDnr9vITxSTVwJiN9PMvN6fPnVC8qK2FtqKyUpKgRzfT1QYmT2uA1jJlOPRBlXKyaLDn U9d4OtrunxMISUjFAwBzPg66qqTrK0/Mvsx+47NQ+Kb4SR/os/O38BRscYOAV4ke/IGT QRpKlgxhfvaSxgE2DTcJn9XhvgkFlZqQI2x10ZmnO2eHlV3OfN2zlwaJ2DYQQ2Gw8EQB xHRIPgjkblzfBEaOs7UrOhV2n2WBIYMcKiZ7pz2jEMsQwPRWYrLQ0FdzzjTWxeiijEtK vNHg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:arc-authentication-results; bh=db1tcpvMhOPxHh7gEHGcS9n4WdITJAw6U1+AJ4mEll4=; b=vLxFL9AYYVTV1NskYrFgEO7tqk2WbHsIaPcQF8574bWn8ifWTNexQPQgumTAzkznoh fm+8SuGv1jyKqWjKWLfgPyJhQimkk/rDlkY1RcA4kpATKnyUBNQhI9EFb+Tj3pyzoxDD waLL6RBFFyt8RvQz7i8SzMUyg6cUta8kvXRe4CWw7xrrPDdyTpUhgdSh7oVNTPMvHV8k JIyX5GW4Ga5GPCeC0Qnxju7LjtH1T/oJ2kNwADJyVruSU5Mfscs2Q43C+U5JYclaZwOE eutQI1AMp5u4xTJJ9Df6nrYS505s7JrNQ+DLtaETCD8jEPH76k0Gobrvwza0IlWyrTwT OoLg== 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=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h187-v6si18027339pgc.540.2018.05.09.14.05.04; Wed, 09 May 2018 14:05:20 -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=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S965383AbeEIVEx (ORCPT + 99 others); Wed, 9 May 2018 17:04:53 -0400 Received: from mx2.suse.de ([195.135.220.15]:38649 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S965147AbeEIVEv (ORCPT ); Wed, 9 May 2018 17:04:51 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay1.suse.de (charybdis-ext.suse.de [195.135.220.254]) by mx2.suse.de (Postfix) with ESMTP id 1FE57ABE8; Wed, 9 May 2018 21:04:49 +0000 (UTC) Date: Wed, 9 May 2018 23:04:47 +0200 From: Michal Hocko To: "Darrick J. Wong" Cc: "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 Message-ID: <20180509210447.GX32366@dhcp22.suse.cz> 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.9.5 (2018-04-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed 09-05-18 08:13:51, 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'... Well, I've tried to cover both. Filesystem and IO code paths which allocate while in sensitive context. IO submission is kinda clear but I am not sure what a general term for filsystem code paths would be. I would be greatful for any hints here. > > > 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...' Done > > 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. OK > > > 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 > > 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... fixed > > 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 Thanks for your review! -- Michal Hocko SUSE Labs