Re: [PATCH 2/5] SUNRPC: allow disabling idle timeout

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Apr 18, 2013, at 10:14 AM, "J. Bruce Fields" <bfields@xxxxxxxxxx> wrote:

> On Thu, Apr 18, 2013 at 05:07:03PM +0000, Myklebust, Trond wrote:
>> On Thu, 2013-04-18 at 13:00 -0400, J. Bruce Fields wrote:
>>> On Mon, Apr 15, 2013 at 03:35:04PM -0400, J. Bruce Fields wrote:
>>>> From: "J. Bruce Fields" <bfields@xxxxxxxxxx>
>>>> 
>>>> In the gss-proxy case we don't want to have to reconnect at random--we
>>>> want to connect only on gss-proxy startup when we can steal gss-proxy's
>>>> context to do the connect in the right namespace.
>>>> 
>>>> So, provide a flag that allows the rpc_create caller to turn off the
>>>> idle timeout.
>>> 
>>> Chuck, the basic ideas was your suggestion, does the executation look OK
>>> here?  I had to copy the rpc_create flags down to the xprt_create, I
>>> don't know if that's reasonable.
>> 
>> This patch will conflict with commit
>> b7993cebb841b0da7a33e9d5ce301a9fd3209165 (SUNRPC: Allow rpc_create() to
>> request that TCP slots be unlimited) that was posted on this list
>> earlier this week.
> 
> Oh, sorry, I missed that.
> 
> Presumably then I should just work on top of that and do the same
> thing--define a pair of flags
> {RP_CLNT_CREATE|XPRT_CREATE}_NO_IDLE_TIMEOUT and translate between the
> two in rpc_create.

Agree.

> 
> --b.
> 
>> 
>>> --b.
>>> 
>>>> 
>>>> Signed-off-by: J. Bruce Fields <bfields@xxxxxxxxxx>
>>>> ---
>>>> include/linux/sunrpc/clnt.h |    1 +
>>>> include/linux/sunrpc/xprt.h |    1 +
>>>> net/sunrpc/clnt.c           |    1 +
>>>> net/sunrpc/xprt.c           |    2 ++
>>>> 4 files changed, 5 insertions(+)
>>>> 
>>>> diff --git a/include/linux/sunrpc/clnt.h b/include/linux/sunrpc/clnt.h
>>>> index 2cf4ffa..8164986 100644
>>>> --- a/include/linux/sunrpc/clnt.h
>>>> +++ b/include/linux/sunrpc/clnt.h
>>>> @@ -124,6 +124,7 @@ struct rpc_create_args {
>>>> #define RPC_CLNT_CREATE_NOPING		(1UL << 4)
>>>> #define RPC_CLNT_CREATE_DISCRTRY	(1UL << 5)
>>>> #define RPC_CLNT_CREATE_QUIET		(1UL << 6)
>>>> +#define RPC_CLNT_CREATE_NO_IDLE_TIMEOUT	(1UL << 7)
>>>> 
>>>> struct rpc_clnt *rpc_create(struct rpc_create_args *args);
>>>> struct rpc_clnt	*rpc_bind_new_program(struct rpc_clnt *,
>>>> diff --git a/include/linux/sunrpc/xprt.h b/include/linux/sunrpc/xprt.h
>>>> index 30834be..df28503 100644
>>>> --- a/include/linux/sunrpc/xprt.h
>>>> +++ b/include/linux/sunrpc/xprt.h
>>>> @@ -263,6 +263,7 @@ struct xprt_create {
>>>> 	size_t			addrlen;
>>>> 	const char		*servername;
>>>> 	struct svc_xprt		*bc_xprt;	/* NFSv4.1 backchannel */
>>>> +	unsigned long		flags;
>>>> };
>>>> 
>>>> struct xprt_class {
>>>> diff --git a/net/sunrpc/clnt.c b/net/sunrpc/clnt.c
>>>> index dcc446e..a41d64a 100644
>>>> --- a/net/sunrpc/clnt.c
>>>> +++ b/net/sunrpc/clnt.c
>>>> @@ -411,6 +411,7 @@ struct rpc_clnt *rpc_create(struct rpc_create_args *args)
>>>> 		.addrlen = args->addrsize,
>>>> 		.servername = args->servername,
>>>> 		.bc_xprt = args->bc_xprt,
>>>> +		.flags = args->flags,
>>>> 	};
>>>> 	char servername[48];
>>>> 
>>>> diff --git a/net/sunrpc/xprt.c b/net/sunrpc/xprt.c
>>>> index b7478d5..37cbc37 100644
>>>> --- a/net/sunrpc/xprt.c
>>>> +++ b/net/sunrpc/xprt.c
>>>> @@ -1245,6 +1245,8 @@ found:
>>>> 				-PTR_ERR(xprt));
>>>> 		goto out;
>>>> 	}
>>>> +	if (args->flags & RPC_CLNT_CREATE_NO_IDLE_TIMEOUT)
>>>> +		xprt->idle_timeout = 0;
>>>> 	INIT_WORK(&xprt->task_cleanup, xprt_autoclose);
>>>> 	if (xprt_has_timer(xprt))
>>>> 		setup_timer(&xprt->timer, xprt_init_autodisconnect,
>>>> -- 
>>>> 1.7.9.5
>>>> 
>>>> --
>>>> To unsubscribe from this list: send the line "unsubscribe linux-nfs" in
>>>> the body of a message to majordomo@xxxxxxxxxxxxxxx
>>>> More majordomo info at  http://vger.kernel.org/majordomo-info.html
>>> --
>>> To unsubscribe from this list: send the line "unsubscribe linux-nfs" in
>>> the body of a message to majordomo@xxxxxxxxxxxxxxx
>>> More majordomo info at  http://vger.kernel.org/majordomo-info.html
>> 
>> 
>> -- 
>> Trond Myklebust
>> Linux NFS client maintainer
>> 
>> NetApp
>> Trond.Myklebust@xxxxxxxxxx
>> www.netapp.com
> --
> To unsubscribe from this list: send the line "unsubscribe linux-nfs" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at  http://vger.kernel.org/majordomo-info.html

--
Chuck Lever
chuck[dot]lever[at]oracle[dot]com



--
To unsubscribe from this list: send the line "unsubscribe linux-nfs" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Linux Filesystem Development]     [Linux USB Development]     [Linux Media Development]     [Video for Linux]     [Linux NILFS]     [Linux Audio Users]     [Yosemite Info]     [Linux SCSI]

  Powered by Linux