Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 8d480326 authored by Trond Myklebust's avatar Trond Myklebust
Browse files

NFSv4: Cap the transport reconnection timer at 1/2 lease period



We don't want to miss a lease period renewal due to the TCP connection
failing to reconnect in a timely fashion. To ensure this doesn't happen,
cap the reconnection timer so that we retry the connection attempt
at least every 1/2 lease period.

Signed-off-by: default avatarTrond Myklebust <trond.myklebust@primarydata.com>
parent fb10fb67
Loading
Loading
Loading
Loading
+3 −0
Original line number Diff line number Diff line
@@ -151,6 +151,9 @@ void nfs4_set_lease_period(struct nfs_client *clp,
	clp->cl_lease_time = lease;
	clp->cl_last_renewal = lastrenewed;
	spin_unlock(&clp->cl_lock);

	/* Cap maximum reconnect timeout at 1/2 lease period */
	rpc_cap_max_reconnect_timeout(clp->cl_rpcclient, lease >> 1);
}

/*
+2 −0
Original line number Diff line number Diff line
@@ -195,6 +195,8 @@ int rpc_clnt_add_xprt(struct rpc_clnt *, struct xprt_create *,
				struct rpc_xprt *,
				void *),
			void *data);
void		rpc_cap_max_reconnect_timeout(struct rpc_clnt *clnt,
			unsigned long timeo);

const char *rpc_proc_name(const struct rpc_task *task);
#endif /* __KERNEL__ */
+21 −0
Original line number Diff line number Diff line
@@ -2676,6 +2676,27 @@ int rpc_clnt_add_xprt(struct rpc_clnt *clnt,
}
EXPORT_SYMBOL_GPL(rpc_clnt_add_xprt);

static int
rpc_xprt_cap_max_reconnect_timeout(struct rpc_clnt *clnt,
		struct rpc_xprt *xprt,
		void *data)
{
	unsigned long timeout = *((unsigned long *)data);

	if (timeout < xprt->max_reconnect_timeout)
		xprt->max_reconnect_timeout = timeout;
	return 0;
}

void
rpc_cap_max_reconnect_timeout(struct rpc_clnt *clnt, unsigned long timeo)
{
	rpc_clnt_iterate_for_each_xprt(clnt,
			rpc_xprt_cap_max_reconnect_timeout,
			&timeo);
}
EXPORT_SYMBOL_GPL(rpc_cap_max_reconnect_timeout);

#if IS_ENABLED(CONFIG_SUNRPC_DEBUG)
static void rpc_show_header(void)
{