diff options
| author | David Xu <davidxu@FreeBSD.org> | 2003-06-11 01:08:33 +0000 |
|---|---|---|
| committer | David Xu <davidxu@FreeBSD.org> | 2003-06-11 01:08:33 +0000 |
| commit | 7677ce18b88609f5f5269a07f5d8b4d568c9713f (patch) | |
| tree | 91b0355af22d00b486ee1180e49944af24b92dd8 /sys/kern/kern_thread.c | |
| parent | 677b542ea243380af64822b30e4ef5f7a6d978ee (diff) | |
Notes
Diffstat (limited to 'sys/kern/kern_thread.c')
| -rw-r--r-- | sys/kern/kern_thread.c | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/sys/kern/kern_thread.c b/sys/kern/kern_thread.c index 367f97b77df7..bb4e3f0819d8 100644 --- a/sys/kern/kern_thread.c +++ b/sys/kern/kern_thread.c @@ -1637,6 +1637,7 @@ thread_userret(struct thread *td, struct trapframe *frame) max_threads_hits++; PROC_LOCK(p); mtx_lock_spin(&sched_lock); + p->p_maxthrwaits++; while (p->p_numthreads > max_threads_per_proc) { upcalls = 0; FOREACH_KSEGRP_IN_PROC(p, kg2) { @@ -1648,13 +1649,15 @@ thread_userret(struct thread *td, struct trapframe *frame) if (upcalls >= max_threads_per_proc) break; mtx_unlock_spin(&sched_lock); - p->p_maxthrwaits++; if (msleep(&p->p_numthreads, &p->p_mtx, PPAUSE|PCATCH, - "maxthreads", NULL)) - break; - p->p_maxthrwaits--; - mtx_lock_spin(&sched_lock); + "maxthreads", NULL)) { + mtx_lock_spin(&sched_lock); + break; + } else { + mtx_lock_spin(&sched_lock); + } } + p->p_maxthrwaits--; mtx_unlock_spin(&sched_lock); PROC_UNLOCK(p); } |
