Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932921AbcCTBzX (ORCPT ); Sat, 19 Mar 2016 21:55:23 -0400 Received: from zeniv.linux.org.uk ([195.92.253.2]:38763 "EHLO ZenIV.linux.org.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932619AbcCTBzN (ORCPT ); Sat, 19 Mar 2016 21:55:13 -0400 Date: Sun, 20 Mar 2016 01:55:11 +0000 From: Al Viro To: Linus Torvalds Cc: Benjamin LaHaise , Dave Chinner , Andrew Morton , linux-fsdevel , Linux API , Linux Kernel Mailing List , linux-aio@kvack.org, linux-mm Subject: Re: aio openat Re: [PATCH 07/13] aio: enabled thread based async fsync Message-ID: <20160320015511.GZ17997@ZenIV.linux.org.uk> References: <20160120195957.GV6033@dastard> <20160120204449.GC12249@kvack.org> <20160120214546.GX6033@dastard> <20160123043922.GF6033@dastard> <20160314171737.GK17923@kvack.org> <20160320012610.GX17997@ZenIV.linux.org.uk> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.5.21 (2010-09-15) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 609 Lines: 13 On Sat, Mar 19, 2016 at 06:45:19PM -0700, Linus Torvalds wrote: > It actually does seem to do that, although in an admittedly rather > questionable way. > > I think it should use path_openat() rather than do_filp_open(), but > passing in LOOKUP_RCU to do_filp_open() actually does work: it just > means that the retry after ECHILD/ESTALE will just do it *again* with > LOOKUP_RCU. It won't fall back to non-rcu mode, it just won't or in > the LOOKUP_RCU flag that is already set. What would make unlazy_walk() fail? And if it succeeds, you are not in RCU mode anymore *without* restarting from scratch...