fuse: release temporary page if fuse_writepage_locked() failed
authorMaxim Patlasov <MPatlasov@parallels.com>
Thu, 10 Jul 2014 11:32:43 +0000 (15:32 +0400)
committerMiklos Szeredi <mszeredi@suse.cz>
Mon, 14 Jul 2014 14:17:57 +0000 (16:17 +0200)
tmp_page to be freed if fuse_write_file_get() returns NULL.

Signed-off-by: Maxim Patlasov <mpatlasov@parallels.com>
Signed-off-by: Miklos Szeredi <mszeredi@suse.cz>
fs/fuse/file.c

index 96d513e..35b6f31 100644 (file)
@@ -1722,7 +1722,7 @@ static int fuse_writepage_locked(struct page *page)
        error = -EIO;
        req->ff = fuse_write_file_get(fc, fi);
        if (!req->ff)
-               goto err_free;
+               goto err_nofile;
 
        fuse_write_fill(req, req->ff, page_offset(page), 0);
 
@@ -1750,6 +1750,8 @@ static int fuse_writepage_locked(struct page *page)
 
        return 0;
 
+err_nofile:
+       __free_page(tmp_page);
 err_free:
        fuse_request_free(req);
 err: