OpenVZ Forum


Home » Mailing lists » Devel » [PATCH] SUNRPC: skip dead but not buried clients on PipeFS events
Re: [PATCH] SUNRPC: skip dead but not buried clients on PipeFS events [message #45938 is a reply to message #45937] Thu, 19 April 2012 11:36 Go to previous messageGo to previous message
Stanislav Kinsbursky is currently offline  Stanislav Kinsbursky
Messages: 683
Registered: October 2011
Senior Member
Sorry, but ignore this patch too.
It can't be that simple because of these cl_count tricks in rpc_release_client...

19.04.2012 14:57, Stanislav Kinsbursky пишет:
> These clients can't be safely dereferenced if their counter in 0.
>
> Signee-off-by: Stanislav Kinsbursky<skinsbursky@parallels.com>
>
> Signed-off-by: Stanislav Kinsbursky<skinsbursky@parallels.com>
>
> ---
> net/sunrpc/clnt.c | 3 ++-
> 1 files changed, 2 insertions(+), 1 deletions(-)
>
> diff --git a/net/sunrpc/clnt.c b/net/sunrpc/clnt.c
> index 6797246..591994d 100644
> --- a/net/sunrpc/clnt.c
> +++ b/net/sunrpc/clnt.c
> @@ -218,7 +218,8 @@ static struct rpc_clnt *rpc_get_client_for_event(struct net *net, int event)
> if (((event == RPC_PIPEFS_MOUNT)&& clnt->cl_dentry) ||
> ((event == RPC_PIPEFS_UMOUNT)&& !clnt->cl_dentry))
> continue;
> - atomic_inc(&clnt->cl_count);
> + if (atomic_inc_return(&clnt->cl_count) == 1)
> + continue;
> spin_unlock(&sn->rpc_client_lock);
> return clnt;
> }
>


--
Best regards,
Stanislav Kinsbursky
 
Read Message
Read Message
Read Message
Read Message
Previous Topic: [PATCH] LockD: call per-net shutdown on every global shutdown call
Next Topic: [PATCH 1/3] SUNRPC: skip clients with program without PipeFS entries
Goto Forum:
  


Current Time: Fri Oct 10 20:40:24 GMT 2025

Total time taken to generate the page: 0.13220 seconds