diff options
| author | Konstantin Belousov <kib@FreeBSD.org> | 2014-12-08 16:33:18 +0000 |
|---|---|---|
| committer | Konstantin Belousov <kib@FreeBSD.org> | 2014-12-08 16:33:18 +0000 |
| commit | f87c8878e6d8b0b8cfc898357be34644776894b7 (patch) | |
| tree | 38351ddb6510c4d236cd11c5d6015361bbef0d62 /sys/rpc | |
| parent | 07a9368a4880e8e972fe873452241f8615bb1a26 (diff) | |
Notes
Diffstat (limited to 'sys/rpc')
| -rw-r--r-- | sys/rpc/svc.c | 20 |
1 files changed, 16 insertions, 4 deletions
diff --git a/sys/rpc/svc.c b/sys/rpc/svc.c index 95d4c49c1ab0..75d9d6edce7f 100644 --- a/sys/rpc/svc.c +++ b/sys/rpc/svc.c @@ -1101,6 +1101,7 @@ svc_run_internal(SVCGROUP *grp, bool_t ismaster) SVCXPRT *xprt; enum xprt_stat stat; struct svc_req *rqstp; + struct proc *p; size_t sz; int error; @@ -1183,11 +1184,22 @@ svc_run_internal(SVCGROUP *grp, bool_t ismaster) > grp->sg_minthreads) && !st->st_xprt) break; - } else if (error) { + } else if (error != 0) { + KASSERT(error == EINTR || error == ERESTART, + ("non-signal error %d", error)); mtx_unlock(&grp->sg_lock); - svc_exit(pool); - mtx_lock(&grp->sg_lock); - break; + p = curproc; + PROC_LOCK(p); + if (P_SHOULDSTOP(p)) { + thread_suspend_check(0); + PROC_UNLOCK(p); + mtx_lock(&grp->sg_lock); + } else { + PROC_UNLOCK(p); + svc_exit(pool); + mtx_lock(&grp->sg_lock); + break; + } } continue; } |
