diff options
Diffstat (limited to 'fs/nfs_common/grace.c')
| -rw-r--r-- | fs/nfs_common/grace.c | 34 | 
1 files changed, 20 insertions, 14 deletions
diff --git a/fs/nfs_common/grace.c b/fs/nfs_common/grace.c index 420d3a0ab258..5be08f02a76b 100644 --- a/fs/nfs_common/grace.c +++ b/fs/nfs_common/grace.c @@ -30,7 +30,11 @@ locks_start_grace(struct net *net, struct lock_manager *lm)  	struct list_head *grace_list = net_generic(net, grace_net_id);  	spin_lock(&grace_lock); -	list_add(&lm->list, grace_list); +	if (list_empty(&lm->list)) +		list_add(&lm->list, grace_list); +	else +		WARN(1, "double list_add attempt detected in net %x %s\n", +		     net->ns.inum, (net == &init_net) ? "(init_net)" : "");  	spin_unlock(&grace_lock);  }  EXPORT_SYMBOL_GPL(locks_start_grace); @@ -55,14 +59,7 @@ locks_end_grace(struct lock_manager *lm)  }  EXPORT_SYMBOL_GPL(locks_end_grace); -/** - * locks_in_grace - * - * Lock managers call this function to determine when it is OK for them - * to answer ordinary lock requests, and when they should accept only - * lock reclaims. - */ -int +static bool  __state_in_grace(struct net *net, bool open)  {  	struct list_head *grace_list = net_generic(net, grace_net_id); @@ -78,15 +75,22 @@ __state_in_grace(struct net *net, bool open)  	return false;  } -int locks_in_grace(struct net *net) +/** + * locks_in_grace + * + * Lock managers call this function to determine when it is OK for them + * to answer ordinary lock requests, and when they should accept only + * lock reclaims. + */ +bool locks_in_grace(struct net *net)  { -	return __state_in_grace(net, 0); +	return __state_in_grace(net, false);  }  EXPORT_SYMBOL_GPL(locks_in_grace); -int opens_in_grace(struct net *net) +bool opens_in_grace(struct net *net)  { -	return __state_in_grace(net, 1); +	return __state_in_grace(net, true);  }  EXPORT_SYMBOL_GPL(opens_in_grace); @@ -104,7 +108,9 @@ grace_exit_net(struct net *net)  {  	struct list_head *grace_list = net_generic(net, grace_net_id); -	BUG_ON(!list_empty(grace_list)); +	WARN_ONCE(!list_empty(grace_list), +		  "net %x %s: grace_list is not empty\n", +		  net->ns.inum, __func__);  }  static struct pernet_operations grace_net_ops = {  | 

