diff options
author | J. Bruce Fields <bfields@citi.umich.edu> | 2007-05-11 16:09:32 -0400 |
---|---|---|
committer | J. Bruce Fields <bfields@citi.umich.edu> | 2007-07-18 19:17:19 -0400 |
commit | 6d34ac199a4af5c678a3a8f3275aeb2586b72da3 (patch) | |
tree | 4ab6cffcfe993baa0afb2ab361a8c94ebfc3a444 | |
parent | 370f6599e8bc03fd9fc6d1a1be00ae0c6373ca59 (diff) |
locks: make posix_test_lock() interface more consistent
Since posix_test_lock(), like fcntl() and ->lock(), indicates absence or
presence of a conflict lock by setting fl_type to, respectively, F_UNLCK
or something other than F_UNLCK, the return value is no longer needed.
Signed-off-by: "J. Bruce Fields" <bfields@citi.umich.edu>
-rw-r--r-- | fs/locks.c | 10 | ||||
-rw-r--r-- | fs/nfs/file.c | 4 | ||||
-rw-r--r-- | include/linux/fs.h | 2 |
3 files changed, 8 insertions, 8 deletions
diff --git a/fs/locks.c b/fs/locks.c index 4c73b857dded..4a8072736efa 100644 --- a/fs/locks.c +++ b/fs/locks.c | |||
@@ -659,7 +659,7 @@ static int locks_block_on_timeout(struct file_lock *blocker, struct file_lock *w | |||
659 | return result; | 659 | return result; |
660 | } | 660 | } |
661 | 661 | ||
662 | int | 662 | void |
663 | posix_test_lock(struct file *filp, struct file_lock *fl) | 663 | posix_test_lock(struct file *filp, struct file_lock *fl) |
664 | { | 664 | { |
665 | struct file_lock *cfl; | 665 | struct file_lock *cfl; |
@@ -671,14 +671,12 @@ posix_test_lock(struct file *filp, struct file_lock *fl) | |||
671 | if (posix_locks_conflict(cfl, fl)) | 671 | if (posix_locks_conflict(cfl, fl)) |
672 | break; | 672 | break; |
673 | } | 673 | } |
674 | if (cfl) { | 674 | if (cfl) |
675 | __locks_copy_lock(fl, cfl); | 675 | __locks_copy_lock(fl, cfl); |
676 | unlock_kernel(); | 676 | else |
677 | return 1; | ||
678 | } else | ||
679 | fl->fl_type = F_UNLCK; | 677 | fl->fl_type = F_UNLCK; |
680 | unlock_kernel(); | 678 | unlock_kernel(); |
681 | return 0; | 679 | return; |
682 | } | 680 | } |
683 | 681 | ||
684 | EXPORT_SYMBOL(posix_test_lock); | 682 | EXPORT_SYMBOL(posix_test_lock); |
diff --git a/fs/nfs/file.c b/fs/nfs/file.c index 13ac6fa2b62b..c87dc713b5d7 100644 --- a/fs/nfs/file.c +++ b/fs/nfs/file.c | |||
@@ -402,7 +402,9 @@ static int do_getlk(struct file *filp, int cmd, struct file_lock *fl) | |||
402 | 402 | ||
403 | lock_kernel(); | 403 | lock_kernel(); |
404 | /* Try local locking first */ | 404 | /* Try local locking first */ |
405 | if (posix_test_lock(filp, fl)) { | 405 | posix_test_lock(filp, fl); |
406 | if (fl->fl_type != F_UNLCK) { | ||
407 | /* found a conflict */ | ||
406 | goto out; | 408 | goto out; |
407 | } | 409 | } |
408 | 410 | ||
diff --git a/include/linux/fs.h b/include/linux/fs.h index b188c2e5338d..80deaaf1b746 100644 --- a/include/linux/fs.h +++ b/include/linux/fs.h | |||
@@ -862,7 +862,7 @@ extern void locks_init_lock(struct file_lock *); | |||
862 | extern void locks_copy_lock(struct file_lock *, struct file_lock *); | 862 | extern void locks_copy_lock(struct file_lock *, struct file_lock *); |
863 | extern void locks_remove_posix(struct file *, fl_owner_t); | 863 | extern void locks_remove_posix(struct file *, fl_owner_t); |
864 | extern void locks_remove_flock(struct file *); | 864 | extern void locks_remove_flock(struct file *); |
865 | extern int posix_test_lock(struct file *, struct file_lock *); | 865 | extern void posix_test_lock(struct file *, struct file_lock *); |
866 | extern int posix_lock_file(struct file *, struct file_lock *, struct file_lock *); | 866 | extern int posix_lock_file(struct file *, struct file_lock *, struct file_lock *); |
867 | extern int posix_lock_file_wait(struct file *, struct file_lock *); | 867 | extern int posix_lock_file_wait(struct file *, struct file_lock *); |
868 | extern int posix_unblock_lock(struct file *, struct file_lock *); | 868 | extern int posix_unblock_lock(struct file *, struct file_lock *); |