From 99ac9c0fde5815b16e5c724fe64be4dc47d5366d Mon Sep 17 00:00:00 2001 From: Miklos Szeredi Date: Thu, 16 Feb 2006 10:08:32 +0000 Subject: fix --- kernel/file.c | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) (limited to 'kernel/file.c') diff --git a/kernel/file.c b/kernel/file.c index be9cc39..77c540e 100644 --- a/kernel/file.c +++ b/kernel/file.c @@ -130,9 +130,14 @@ int fuse_open_common(struct inode *inode, struct file *file, int isdir) /* Special case for failed iget in CREATE */ static void fuse_release_end(struct fuse_conn *fc, struct fuse_req *req) { - u64 nodeid = req->in.h.nodeid; - fuse_reset_request(req); - fuse_send_forget(fc, req, nodeid, 1); + /* If called from end_io_requests(), req has more than one + reference and fuse_reset_request() cannot work */ + if (fc->connected) { + u64 nodeid = req->in.h.nodeid; + fuse_reset_request(req); + fuse_send_forget(fc, req, nodeid, 1); + } else + fuse_put_request(fc, req); } void fuse_send_release(struct fuse_conn *fc, struct fuse_file *ff, -- cgit v1.2.3