Return-Path: Received: from mx2.suse.de ([195.135.220.15]:45083 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755069AbcLSJg6 (ORCPT ); Mon, 19 Dec 2016 04:36:58 -0500 Date: Fri, 16 Dec 2016 09:39:35 +0100 From: Jan Kara To: Michal Hocko Cc: linux-mm@kvack.org, linux-fsdevel@vger.kernel.org, Andrew Morton , Dave Chinner , "Theodore Ts'o" , Chris Mason , David Sterba , Jan Kara , ceph-devel@vger.kernel.org, cluster-devel@redhat.com, linux-nfs@vger.kernel.org, logfs@logfs.org, linux-xfs@vger.kernel.org, linux-ext4@vger.kernel.org, linux-btrfs@vger.kernel.org, linux-mtd@lists.infradead.org, reiserfs-devel@vger.kernel.org, linux-ntfs-dev@lists.sourceforge.net, linux-f2fs-devel@lists.sourceforge.net, linux-afs@lists.infradead.org, LKML , Michal Hocko Subject: Re: [PATCH 6/9] jbd2: mark the transaction context with the scope GFP_NOFS context Message-ID: <20161216083935.GD26608@quack2.suse.cz> References: <20161215140715.12732-1-mhocko@kernel.org> <20161215140715.12732-7-mhocko@kernel.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii In-Reply-To: <20161215140715.12732-7-mhocko@kernel.org> Sender: linux-nfs-owner@vger.kernel.org List-ID: On Thu 15-12-16 15:07:12, Michal Hocko wrote: > From: Michal Hocko > > now that we have memalloc_nofs_{save,restore} api we can mark the whole > transaction context as implicitly GFP_NOFS. All allocations will > automatically inherit GFP_NOFS this way. This means that we do not have > to mark any of those requests with GFP_NOFS and moreover all the > ext4_kv[mz]alloc(GFP_NOFS) are also safe now because even the hardcoded > GFP_KERNEL allocations deep inside the vmalloc will be NOFS now. > > Signed-off-by: Michal Hocko Looks good to me. You can add: Reviewed-by: Jan Kara Honza > --- > fs/jbd2/transaction.c | 11 +++++++++++ > include/linux/jbd2.h | 2 ++ > 2 files changed, 13 insertions(+) > > diff --git a/fs/jbd2/transaction.c b/fs/jbd2/transaction.c > index e1652665bd93..35a5d3d76182 100644 > --- a/fs/jbd2/transaction.c > +++ b/fs/jbd2/transaction.c > @@ -388,6 +388,11 @@ static int start_this_handle(journal_t *journal, handle_t *handle, > > rwsem_acquire_read(&journal->j_trans_commit_map, 0, 0, _THIS_IP_); > jbd2_journal_free_transaction(new_transaction); > + /* > + * Make sure that no allocations done while the transaction is > + * open is going to recurse back to the fs layer. > + */ > + handle->saved_alloc_context = memalloc_nofs_save(); > return 0; > } > > @@ -466,6 +471,7 @@ handle_t *jbd2__journal_start(journal_t *journal, int nblocks, int rsv_blocks, > trace_jbd2_handle_start(journal->j_fs_dev->bd_dev, > handle->h_transaction->t_tid, type, > line_no, nblocks); > + > return handle; > } > EXPORT_SYMBOL(jbd2__journal_start); > @@ -1760,6 +1766,11 @@ int jbd2_journal_stop(handle_t *handle) > if (handle->h_rsv_handle) > jbd2_journal_free_reserved(handle->h_rsv_handle); > free_and_exit: > + /* > + * scope of th GFP_NOFS context is over here and so we can > + * restore the original alloc context. > + */ > + memalloc_nofs_restore(handle->saved_alloc_context); > jbd2_free_handle(handle); > return err; > } > diff --git a/include/linux/jbd2.h b/include/linux/jbd2.h > index dfaa1f4dcb0c..606b6bce3a5b 100644 > --- a/include/linux/jbd2.h > +++ b/include/linux/jbd2.h > @@ -491,6 +491,8 @@ struct jbd2_journal_handle > > unsigned long h_start_jiffies; > unsigned int h_requested_credits; > + > + unsigned int saved_alloc_context; > }; > > > -- > 2.10.2 > -- Jan Kara SUSE Labs, CR