[prev in list] [next in list] [prev in thread] [next in thread] 

List:       linux-fsdevel
Subject:    [PATCH 3 of 10] RESEND lease interfaces for version 4 NFSD
From:       Andy Adamson <andros () thnk ! citi ! umich ! edu>
Date:       2004-09-21 22:35:50
Message-ID: 1095804047.21441d5b.3 () citi ! umich ! edu
[Download RAW message or body]

VFS: add a lock manager break callback to break_lease() for lock managers to
initiate breaking a lease.

VFS: move the break_lease() kill_fasync() call to a default lock manager
fl_break callback

Signed-off-by: Andy Adamson <andros@citi.umich.edu>
---

 linux-2.6.9-rc2-andros/fs/locks.c         |   15 ++++++++++++++-
 linux-2.6.9-rc2-andros/include/linux/fs.h |    1 +
 2 files changed, 15 insertions(+), 1 deletion(-)

diff -puN fs/locks.c~lmops-break fs/locks.c
--- linux-2.6.9-rc2/fs/locks.c~lmops-break	2004-09-21 18:00:24.902181472 -0400
+++ linux-2.6.9-rc2-andros/fs/locks.c	2004-09-21 18:00:24.909180408 -0400
@@ -390,6 +390,16 @@ static int flock64_to_posix_lock(struct 
 }
 #endif
 
+/* default lease lock manager operations */
+static void lease_break_callback(struct file_lock *fl)
+{
+	kill_fasync(&fl->fl_fasync, SIGIO, POLL_MSG);
+}
+
+struct lock_manager_operations lease_manager_ops = {
+	.fl_break = lease_break_callback,
+};
+
 /* Allocate a file_lock initialised to this type of lease */
 static int lease_alloc(struct file *filp, int type, struct file_lock **flp)
 {
@@ -1125,7 +1135,10 @@ int __break_lease(struct inode *inode, u
 		if (fl->fl_type != future) {
 			fl->fl_type = future;
 			fl->fl_break_time = break_time;
-			kill_fasync(&fl->fl_fasync, SIGIO, POLL_MSG);
+			if (fl->fl_lmops && fl->fl_lmops->fl_break)
+				fl->fl_lmops->fl_break(fl);
+			else    /* lease must have lmops break callback */
+				BUG();
 		}
 	}
 
diff -puN include/linux/fs.h~lmops-break include/linux/fs.h
--- linux-2.6.9-rc2/include/linux/fs.h~lmops-break	2004-09-21 18:00:24.904181168 -0400
+++ linux-2.6.9-rc2-andros/include/linux/fs.h	2004-09-21 18:00:24.910180256 -0400
@@ -635,6 +635,7 @@ struct lock_manager_operations {
 	void (*fl_notify)(struct file_lock *);	/* unblock callback */
 	void (*fl_copy_lock)(struct file_lock *, struct file_lock *);
 	void (*fl_release_private)(struct file_lock *);
+	void (*fl_break)(struct file_lock *);
 };
 
 /* that will die - we need it for nfs_lock_info */
_
-
To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
[prev in list] [next in list] [prev in thread] [next in thread] 

Configure | About | News | Add a list | Sponsored by KoreLogic