aboutsummaryrefslogtreecommitdiffstats
path: root/lib/fuse_session.c
diff options
context:
space:
mode:
authorMiklos Szeredi <mszeredi@suse.cz>2013-06-20 11:43:02 +0200
committerMiklos Szeredi <mszeredi@suse.cz>2013-07-01 10:06:37 +0200
commitddfd2d44a6eab79c722f4b5785efdbcccb9c4d35 (patch)
tree9d3b4d9ae8a687c97761b2200f448bf88ad2c53e /lib/fuse_session.c
parent44088bc7fbe7c9234c090756dbf10742b1a281b1 (diff)
downloadandroid_external_fuse-ddfd2d44a6eab79c722f4b5785efdbcccb9c4d35.tar.gz
android_external_fuse-ddfd2d44a6eab79c722f4b5785efdbcccb9c4d35.tar.bz2
android_external_fuse-ddfd2d44a6eab79c722f4b5785efdbcccb9c4d35.zip
libfuse: fix multiple close of device fd
- fuse_kern_unmount closes handle (e.g. 19) - a thread in my process opens a file - the OS assigns newly freed handle (i.e. 19) - fuse_kern_chan_destroy closes the same handle (i.e. 19) - a thread in my process opens another file - the OS assigns newly freed handle (i.e. 19) - * MAYHEM * Reported by Dan Greenfield
Diffstat (limited to 'lib/fuse_session.c')
-rw-r--r--lib/fuse_session.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/lib/fuse_session.c b/lib/fuse_session.c
index c55f250..6e11068 100644
--- a/lib/fuse_session.c
+++ b/lib/fuse_session.c
@@ -182,6 +182,13 @@ int fuse_chan_fd(struct fuse_chan *ch)
return ch->fd;
}
+int fuse_chan_clearfd(struct fuse_chan *ch)
+{
+ int fd = ch->fd;
+ ch->fd = -1;
+ return fd;
+}
+
size_t fuse_chan_bufsize(struct fuse_chan *ch)
{
return ch->bufsize;