On Wed, Aug 10, 2016 at 6:50 PM, Enke Chen <enkechen@xxxxxxxxx> wrote: > Hi, Miklos: > > On 8/9/16 11:52 PM, Miklos Szeredi wrote: >> On Wed, Aug 10, 2016 at 5:26 AM, Enke Chen <enkechen@xxxxxxxxx> wrote: >>> Hi, Miklos: >>> >>> This patch adds the async option for the flush/release operation in FUSE. >>> >>> The async flush/release option allows a FUSE-based application to be terminated >>> without being blocked in the flush/release operation even in the presence of >>> complex external interactions. In addition, the async operation can be more >>> efficient when a large number of fuse-based files is involved. >>> >>> --- >>> Deadlock Example: >>> >>> Process A is a multi-threaded application that interacts with Process B, >>> a FUSE-server. >>> >>> >>> UNIX-domain socket >>> App (A) ----------------------- FUSE-server (B) >>> | | >>> | | >>> | | >>> +-----------------------------------+ >>> open/flush/release >> >> Why would the fuse server want to communicate with the app (using >> other than the filesystem)? > > In this particular case, the other communication channel is used to coordinate > the allocation (with "open") and de-alocation (with "flush/release") of the > shared memory associated with the opened "file". > > In general an application may have special handling for the "flush/release" > operation that involve external interactions with one or more other processes, Sure, it can interact with other processes, but *not* with the process accessing the filesystem. There are no end of possible deadlocks that way, and it goes straight against the design philosophy of kernel interfaces. Maybe I'm missing something, but this sure looks like a case of bad system design. You need to give more details to convince me otherwise. > and that is where this "async" operation can help. > > IMO it would be even better if the "async" operation can be made the default so > folks do not need to worry about this types of deadlocks. From reading of the > code, it seems that FUSE does "async" release under certain conditions already. Release being async is okay, and is the default for non-fuseblk mounts. For fuseblk it is not the default, because it could cause problems: 5a18ec176c93 ("fuse: fix hang of single threaded fuseblk filesystem") We could make release optionally async for fuseblk. Flush being async is not okay, it needs to return an error value. If the filesystem does not want to return an error value, it may omit a flush implementation completely. Thanks, Miklos -- To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html