提交 ccd0a0bd 编写于 作者: M Miklos Szeredi

fuse: call fuse_abort_conn() in dev release

fuse_abort_conn() does all the work done by fuse_dev_release() and more.
"More" consists of:

	end_io_requests(fc);
	wake_up_all(&fc->waitq);
	kill_fasync(&fc->fasync, SIGIO, POLL_IN);

All of which should be no-op (WARN_ON's added).
Signed-off-by: NMiklos Szeredi <mszeredi@suse.cz>
Reviewed-by: NAshish Samant <ashish.samant@oracle.com>
上级 f0139aa8
...@@ -2199,14 +2199,9 @@ int fuse_dev_release(struct inode *inode, struct file *file) ...@@ -2199,14 +2199,9 @@ int fuse_dev_release(struct inode *inode, struct file *file)
{ {
struct fuse_conn *fc = fuse_get_conn(file); struct fuse_conn *fc = fuse_get_conn(file);
if (fc) { if (fc) {
spin_lock(&fc->lock); WARN_ON(!list_empty(&fc->io));
fc->connected = 0; WARN_ON(fc->fasync != NULL);
fc->blocked = 0; fuse_abort_conn(fc);
fuse_set_initialized(fc);
end_queued_requests(fc);
end_polls(fc);
wake_up_all(&fc->blocked_waitq);
spin_unlock(&fc->lock);
fuse_conn_put(fc); fuse_conn_put(fc);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册