On Wed, Sep 20, 2017 at 09:17:25AM +0300, Avi Kivity wrote: > On 09/19/2017 08:39 PM, Brian Foster wrote: > > On Tue, Sep 19, 2017 at 07:31:04PM +0300, Avi Kivity wrote: > > > > > > On 09/19/2017 05:58 PM, Christoph Hellwig wrote: > > > > On Tue, Sep 19, 2017 at 08:27:05AM -0400, Brian Foster wrote: > > > > > > Please advise, is this a known bug? When can it happen? Is there a way > > > > > > to work it around to avoid blocking? > > > > > > > > > > > I'm not sure how either could be considered a bug based on the stack > > > > > trace information alone. Allocations may require reading metadata and > > > > > reads are synchronous. This all seems like pretty basic filesystem > > > > > behavior. > > > > > > > > > > I suppose performance may be a separate question. For the latter issue, > > > > > I'd be curious whether leaving more free space available in the > > > > > filesystem would help avoid running into busy extents. Perhaps having > > > > > more memory and thus a larger buffer cache for btree blocks could help > > > > > mitigate the former issue..? The deterministic workaround for both is to > > > > > preallocate the associated file. If the file would be too large, another > > > > > option may be to set an extent size hint to allocate the file in larger > > > > > chunks and amortize the cost of the allocations over multiple writes. > > > > Note that Linux 4.13 and later support a RWF_NOWAIT flag, that will > > > > return -EAGAIN from io_submit for these conditions so they can be > > > > handled by a thread pool. > > > > > > > > Note that until a few years ago we performed all allocations from > > > > a workqueue, this was changed by: > > > > > > > > commit cf11da9c5d374962913ca5ba0ce0886b58286224 > > > > Author: Dave Chinner <dchinner@xxxxxxxxxx> > > > > Date: Tue Jul 15 07:08:24 2014 +1000 > > > > > > > > xfs: refine the allocation stack switch > > > > > > > > to only defer btree splits to a workqueue. With that previous scheme > > > > there might have been an option to defer AIO allocations to a workqueue, > > > > but the main issue with that is that the worker thread which is then > > > > going to do the actual data transfer would have to "borrow" the > > > > mm_struct from the submitter. That's the primary reason why something > > > > like that was never implemented in mainline Linux. > > > For DIO, does it really need the mm_struct? It can just pin the pages and > > > pass them to the workqueue function. > > > > > I'm not sure what difference it makes regardless. We still have to wait > > for an allocation to complete before we can issue an I/O. > > If io_submit() returns immediately rather than blocking, it makes a huge > difference. Waiting in the workqueue can be done in parallel to other I/O > and in parallel to cpu work in the caller thread. Blocking means no further > I/O is issued and no cpu work is done. > Sure. I'm just saying that seems orthogonal to how/why we deferred block allocations to a wq. Even if we went back to that behavior, io_submit() will still potentially block as it does today. It sounds like what you want is something higher level that defers the entire aio submission to a wq (which still may have to use another wq for btree splits, for different reasons). Apparently we had something like that in the past as Christoph referred to in his last mail, but I'm not really familiar with that. FWIW, this is not exactly the same, but I think Dave prototyped something in the past to wire up aio_fsync() to a basic wq implementation and managed to show really good scalability improvements. Given that, I suppose it wouldn't be that surprising to get similar results for I/O submission if there is some way around the page issue. Brian > > IIRC, the old > > defer allocs to a wq thing was more about saving stack space than > > providing async behavior. > > Perhaps, but IMO the async behavior is a major feature of the aio system > calls. It is very hard to use them if they block. > > -- > To unsubscribe from this list: send the line "unsubscribe linux-xfs" in > the body of a message to majordomo@xxxxxxxxxxxxxxx > More majordomo info at http://vger.kernel.org/majordomo-info.html -- To unsubscribe from this list: send the line "unsubscribe linux-xfs" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html