From: J. Bruce Fields <bfields@xxxxxxxxxxxx> We're using fl_notify to asynchronously return the result of a lock request. So we want fl_notify to be able to return a status and, if appropriate, a conflicting lock. This only current caller of fl_notify is in the blocked case, in which case we don't use these extra arguments. We also allow fl_notify to return an error. (Also ignored for now.) Signed-off-by: J. Bruce Fields <bfields@xxxxxxxxxxxxxx> --- fs/lockd/svclock.c | 7 ++++--- fs/locks.c | 2 +- include/linux/fs.h | 2 +- 3 files changed, 6 insertions(+), 5 deletions(-) diff --git a/fs/lockd/svclock.c b/fs/lockd/svclock.c index 2ce4dc6..32f4cc4 100644 --- a/fs/lockd/svclock.c +++ b/fs/lockd/svclock.c @@ -637,12 +637,13 @@ nlmsvc_cancel_blocked(struct nlm_file *file, struct nlm_lock *lock) * This function doesn't grant the blocked lock instantly, but rather moves * the block to the head of nlm_blocked where it can be picked up by lockd. */ -static void -nlmsvc_notify_blocked(struct file_lock *fl) +static int +nlmsvc_notify_blocked(struct file_lock *fl, struct file_lock *conf, int result) { struct nlm_block *block; - dprintk("lockd: VFS unblock notification for block %p\n", fl); + dprintk("lockd: nlmsvc_notify_blocked lock %p conf %p result %d\n", + fl, conf, result); list_for_each_entry(block, &nlm_blocked, b_list) { if (nlm_compare_locks(&block->b_call->a_args.lock.fl, fl)) { nlmsvc_insert_block(block, 0); diff --git a/fs/locks.c b/fs/locks.c index 451a61a..959347e 100644 --- a/fs/locks.c +++ b/fs/locks.c @@ -544,7 +544,7 @@ static void locks_wake_up_blocks(struct file_lock *blocker) struct file_lock, fl_block); __locks_delete_block(waiter); if (waiter->fl_lmops && waiter->fl_lmops->fl_notify) - waiter->fl_lmops->fl_notify(waiter); + waiter->fl_lmops->fl_notify(waiter, NULL, -EAGAIN); else wake_up(&waiter->fl_wait); } diff --git a/include/linux/fs.h b/include/linux/fs.h index b1d287b..9b57afc 100644 --- a/include/linux/fs.h +++ b/include/linux/fs.h @@ -795,7 +795,7 @@ struct file_lock_operations { struct lock_manager_operations { int (*fl_compare_owner)(struct file_lock *, struct file_lock *); - void (*fl_notify)(struct file_lock *); /* unblock callback */ + int (*fl_notify)(struct file_lock *, struct file_lock *, int); void (*fl_copy_lock)(struct file_lock *, struct file_lock *); void (*fl_release_private)(struct file_lock *); void (*fl_break)(struct file_lock *); -- 1.4.4.1 - To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html