lockd: Remove FL_LOCKD flag
authorJ. Bruce Fields <bfields@fieldses.org>
Mon, 20 Mar 2006 18:44:26 +0000 (13:44 -0500)
committerTrond Myklebust <Trond.Myklebust@netapp.com>
Mon, 20 Mar 2006 18:44:26 +0000 (13:44 -0500)
Currently lockd identifies its own locks using the FL_LOCKD flag.  This
doesn't scale well to multiple lock managers--if we did this in nfsv4 too,
for example, we'd be left with only one free flag bit.

Instead, we just check whether the file manager ops (fl_lmops) set on this
lock are our own.

The only use for this is in nlm_traverse_locks, which uses it to find locks
that need cleaning up when freeing a host or a file.

In the long run it might be nice to do reference counting instead of
traversing all the locks like this....

Signed-off-by: J. Bruce Fields <bfields@citi.umich.edu>
Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
fs/lockd/svclock.c
fs/lockd/svcsubs.c
include/linux/fs.h

index d683dd022e08dd28186083594e8b9fe7bde9434f..d50946dcddd9f850229d5f01b0ac05952eedccb7 100644 (file)
@@ -313,8 +313,6 @@ nlmsvc_lock(struct svc_rqst *rqstp, struct nlm_file *file,
        /* Get existing block (in case client is busy-waiting) */
        block = nlmsvc_lookup_block(file, lock, 0);
 
-       lock->fl.fl_flags |= FL_LOCKD;
-
 again:
        /* Lock file against concurrent access */
        down(&file->f_sema);
index 62f4a385177f355c993ca957cca12974d20e9d27..601e5b3dfe20523c21d5742dab1fa43efb1cca49 100644 (file)
@@ -182,7 +182,7 @@ nlm_traverse_locks(struct nlm_host *host, struct nlm_file *file, int action)
 again:
        file->f_locks = 0;
        for (fl = inode->i_flock; fl; fl = fl->fl_next) {
-               if (!(fl->fl_flags & FL_LOCKD))
+               if (fl->fl_lmops != &nlmsvc_lock_operations)
                        continue;
 
                /* update current lock count */
index 8ef4dd788a8362d4477bccbd3f0b71979287c0bb..d2cffee8fc1183620a31761a1098dfb85b4f0ed5 100644 (file)
@@ -667,7 +667,6 @@ extern spinlock_t files_lock;
 #define FL_POSIX       1
 #define FL_FLOCK       2
 #define FL_ACCESS      8       /* not trying to lock, just looking */
-#define FL_LOCKD       16      /* lock held by rpc.lockd */
 #define FL_LEASE       32      /* lease held on this file */
 #define FL_SLEEP       128     /* A blocking lock */