--- /dev/null
+From nobody Mon Sep 17 00:00:00 2001
+Subject: [PATCH] VFS: Fix memory leak with file leases
+From: J. Bruce Fields <bfields@fieldses.org>
+Date: 1131667680 -0500
+
+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>
+---
+
+ fs/locks.c | 2 +-
+ 1 files changed, 1 insertion(+), 1 deletion(-)
+
+Index: linux-2.6.14.y/fs/locks.c
+===================================================================
+--- linux-2.6.14.y.orig/fs/locks.c
++++ linux-2.6.14.y/fs/locks.c
+@@ -1418,7 +1418,7 @@ int fcntl_setlease(unsigned int fd, stru
+ 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);