Commit 18d19f94 authored by Tom Tucker's avatar Tom Tucker Committed by J. Bruce Fields

svc: Make svc_check_conn_limits xprt independent

The svc_check_conn_limits function only manipulates xprt fields. Change references
to svc_sock->sk_xprt to svc_xprt directly.
Signed-off-by: default avatarTom Tucker <tom@opengridcomputing.com>
Acked-by: default avatarNeil Brown <neilb@suse.de>
Reviewed-by: default avatarChuck Lever <chuck.lever@oracle.com>
Reviewed-by: default avatarGreg Banks <gnb@sgi.com>
Signed-off-by: default avatarJ. Bruce Fields <bfields@citi.umich.edu>
parent 57b1d3ba
...@@ -1448,31 +1448,31 @@ svc_sock_update_bufs(struct svc_serv *serv) ...@@ -1448,31 +1448,31 @@ svc_sock_update_bufs(struct svc_serv *serv)
static void svc_check_conn_limits(struct svc_serv *serv) static void svc_check_conn_limits(struct svc_serv *serv)
{ {
if (serv->sv_tmpcnt > (serv->sv_nrthreads+3)*20) { if (serv->sv_tmpcnt > (serv->sv_nrthreads+3)*20) {
struct svc_sock *svsk = NULL; struct svc_xprt *xprt = NULL;
spin_lock_bh(&serv->sv_lock); spin_lock_bh(&serv->sv_lock);
if (!list_empty(&serv->sv_tempsocks)) { if (!list_empty(&serv->sv_tempsocks)) {
if (net_ratelimit()) { if (net_ratelimit()) {
/* Try to help the admin */ /* Try to help the admin */
printk(KERN_NOTICE "%s: too many open TCP " printk(KERN_NOTICE "%s: too many open "
"sockets, consider increasing the " "connections, consider increasing the "
"number of nfsd threads\n", "number of nfsd threads\n",
serv->sv_name); serv->sv_name);
} }
/* /*
* Always select the oldest socket. It's not fair, * Always select the oldest connection. It's not fair,
* but so is life * but so is life
*/ */
svsk = list_entry(serv->sv_tempsocks.prev, xprt = list_entry(serv->sv_tempsocks.prev,
struct svc_sock, struct svc_xprt,
sk_xprt.xpt_list); xpt_list);
set_bit(XPT_CLOSE, &svsk->sk_xprt.xpt_flags); set_bit(XPT_CLOSE, &xprt->xpt_flags);
svc_xprt_get(&svsk->sk_xprt); svc_xprt_get(xprt);
} }
spin_unlock_bh(&serv->sv_lock); spin_unlock_bh(&serv->sv_lock);
if (svsk) { if (xprt) {
svc_xprt_enqueue(&svsk->sk_xprt); svc_xprt_enqueue(xprt);
svc_xprt_put(&svsk->sk_xprt); svc_xprt_put(xprt);
} }
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment