diff options
author | Miklos Szeredi <miklos@szeredi.hu> | 2005-12-02 11:05:41 +0000 |
---|---|---|
committer | Miklos Szeredi <miklos@szeredi.hu> | 2005-12-02 11:05:41 +0000 |
commit | fa829b5577e6ee2dd8046f488042195bfba496e0 (patch) | |
tree | 8ecbf4ecc80fe698da226edabbc472911b5aa51a | |
parent | 40d7b38b29cb251e84b3619b8040ac248d944e84 (diff) | |
download | libfuse-fa829b5577e6ee2dd8046f488042195bfba496e0.tar.gz |
fix
-rw-r--r-- | ChangeLog | 7 | ||||
-rw-r--r-- | lib/fuse.c | 3 |
2 files changed, 10 insertions, 0 deletions
@@ -1,3 +1,10 @@ +2005-12-02 Miklos Szeredi <miklos@szeredi.hu> + + * Fix memory leak in fuse_read_cmd()/fuse_process_cmd(). Bug + reported by Vincenzo Ciancia + + * Handle exit-by-umount in fuse_read_cmd() + 2005-11-29 Miklos Szeredi <miklos@szeredi.hu> * Check if '-msoft-float' option is supported by compiler when @@ -1742,6 +1742,7 @@ static void free_cmd(struct fuse_cmd *cmd) void fuse_process_cmd(struct fuse *f, struct fuse_cmd *cmd) { fuse_session_process(f->se, cmd->buf, cmd->buflen, cmd->ch); + free_cmd(cmd); } int fuse_exited(struct fuse *f) @@ -1779,6 +1780,8 @@ struct fuse_cmd *fuse_read_cmd(struct fuse *f) int res = fuse_chan_receive(ch, cmd->buf, bufsize); if (res <= 0) { free_cmd(cmd); + if (res == -1) + fuse_exit(f); return NULL; } cmd->buflen = res; |