Douglas Leeder <douglas.leeder@xxxxxxxxxx> wrote: > So as, I sent later, making fanotify only return one file event per fanotify read(), So that suggests that the request is getting stuck in a cycle or adding a request. > > Florian has also been looking at this problem, and has pointed out that FMODE_NONOTIFY should prevent the loop seen in the backtrace, so I'm wondering if it's getting lost somewhere in ecryptfs. Or perhaps it needs to be explicitly propagated to the open request for the lower file? Douglas, can you reproduce the problem with this patch applied? diff --git a/fs/ecryptfs/kthread.c b/fs/ecryptfs/kthread.c index 809e67d..1d8a53b 100644 --- a/fs/ecryptfs/kthread.c +++ b/fs/ecryptfs/kthread.c @@ -74,7 +74,7 @@ static int ecryptfs_threadfn(void *ignored) kthread_ctl_list); list_del(&req->kthread_ctl_list); *req->lower_file = dentry_open(&req->path, - (O_RDWR | O_LARGEFILE), current_cred()); + (O_RDWR | O_LARGEFILE | FMODE_NONOTIFY), current_cred()); complete(&req->done); } mutex_unlock(&ecryptfs_kthread_ctl.mux); @@ -133,7 +133,7 @@ int ecryptfs_privileged_open(struct file **lower_file, const struct cred *cred) { struct ecryptfs_open_req req; - int flags = O_LARGEFILE; + int flags = O_LARGEFILE|FMODE_NONOTIFY; int rc = 0; init_completion(&req.done); -- To unsubscribe from this list: send the line "unsubscribe ecryptfs" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html