aboutsummaryrefslogtreecommitdiffstats
path: root/fs/locks.c
diff options
context:
space:
mode:
authorDavid M. Richter <richterd@citi.umich.edu>2008-04-23 16:29:00 -0400
committerJ. Bruce Fields <bfields@citi.umich.edu>2008-04-25 12:58:22 -0400
commit288b2fd8251cb0bcb14b8a93755ef9c78de70e0f (patch)
tree65ab67c528ad063f8e2103e1bb916bcb6981bd66 /fs/locks.c
parent5fcc60c3a05bf417229fba715e7aec52bf6717fb (diff)
leases: when unlocking, skip locking-related steps
In generic_setlease(), we don't need to allocate a new struct file_lock or check for readers or writers when called with F_UNLCK. Signed-off-by: David M. Richter <richterd@citi.umich.edu> Signed-off-by: J. Bruce Fields <bfields@citi.umich.edu>
Diffstat (limited to 'fs/locks.c')
-rw-r--r--fs/locks.c24
1 files changed, 13 insertions, 11 deletions
diff --git a/fs/locks.c b/fs/locks.c
index b9f3a0bed300..da1d0ddb4abd 100644
--- a/fs/locks.c
+++ b/fs/locks.c
@@ -1367,18 +1367,20 @@ int generic_setlease(struct file *filp, long arg, struct file_lock **flp)
1367 1367
1368 lease = *flp; 1368 lease = *flp;
1369 1369
1370 error = -EAGAIN; 1370 if (arg != F_UNLCK) {
1371 if ((arg == F_RDLCK) && (atomic_read(&inode->i_writecount) > 0)) 1371 error = -EAGAIN;
1372 goto out; 1372 if ((arg == F_RDLCK) && (atomic_read(&inode->i_writecount) > 0))
1373 if ((arg == F_WRLCK) 1373 goto out;
1374 && ((atomic_read(&dentry->d_count) > 1) 1374 if ((arg == F_WRLCK)
1375 || (atomic_read(&inode->i_count) > 1))) 1375 && ((atomic_read(&dentry->d_count) > 1)
1376 goto out; 1376 || (atomic_read(&inode->i_count) > 1)))
1377 goto out;
1377 1378
1378 error = -ENOMEM; 1379 error = -ENOMEM;
1379 new_fl = locks_alloc_lock(); 1380 new_fl = locks_alloc_lock();
1380 if (new_fl == NULL) 1381 if (new_fl == NULL)
1381 goto out; 1382 goto out;
1383 }
1382 1384
1383 /* 1385 /*
1384 * At this point, we know that if there is an exclusive 1386 * At this point, we know that if there is an exclusive