]> git.hungrycats.org Git - linux/commitdiff
[PATCH] VFS: Fix memory leak with file leases
authorJ. Bruce Fields <bfields@fieldses.org>
Fri, 11 Nov 2005 00:08:00 +0000 (19:08 -0500)
committerChris Wright <chrisw@osdl.org>
Thu, 24 Nov 2005 22:10:08 +0000 (14:10 -0800)
The patch
http://linux.bkbits.net:8080/linux-2.6/diffs/fs/locks.c@1.70??nav=index.html
introduced a pretty nasty memory leak in the lease code. When freeing
the lease, the code in locks_delete_lock() will correctly clean up
the fasync queue, but when we return to fcntl_setlease(), the freed
fasync entry will be reinstated.

This patch ensures that we skip the call to fasync_helper() when we're
freeing up the lease.

Signed-off-by: J. Bruce Fields <bfields@fieldses.org>
Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
Signed-off-by: Chris Wright <chrisw@osdl.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
fs/locks.c

index f7daa5f48949c41ea02b687e1521a440387b0592..accbc3c0506f26929216f8af086bd85d0c0aa109 100644 (file)
@@ -1418,7 +1418,7 @@ int fcntl_setlease(unsigned int fd, struct file *filp, long arg)
        lock_kernel();
 
        error = __setlease(filp, arg, &flp);
-       if (error)
+       if (error || arg == F_UNLCK)
                goto out_unlock;
 
        error = fasync_helper(fd, filp, 1, &flp->fl_fasync);