- Move the second stop() of process 'p' in issignal() to be after we send

SIGCHLD to our parent process.  Otherwise, we could block while obtaining
  the process lock for our parent process and switch out while we were
  in SSTOP.  Even worse, when we try to resume from the mutex being blocked
  on our p_stat will be SRUN, not SSTOP.
- Fix a comment above stop() to indicate that it requires that the proc lock
  be held, not a proctree lock.

Reported by:	markm
Sleuthing by:	jake
This commit is contained in:
John Baldwin 2001-04-02 17:26:51 +00:00
parent 899a73c0a6
commit 1333047621

View File

@ -1469,12 +1469,12 @@ issignal(p)
prop & SA_TTYSTOP)) prop & SA_TTYSTOP))
break; /* == ignore */ break; /* == ignore */
p->p_xstat = sig; p->p_xstat = sig;
stop(p);
if ((p->p_pptr->p_procsig->ps_flag & PS_NOCLDSTOP) == 0) { if ((p->p_pptr->p_procsig->ps_flag & PS_NOCLDSTOP) == 0) {
PROC_LOCK(p->p_pptr); PROC_LOCK(p->p_pptr);
psignal(p->p_pptr, SIGCHLD); psignal(p->p_pptr, SIGCHLD);
PROC_UNLOCK(p->p_pptr); PROC_UNLOCK(p->p_pptr);
} }
stop(p);
mtx_lock_spin(&sched_lock); mtx_lock_spin(&sched_lock);
PROC_UNLOCK_NOSWITCH(p); PROC_UNLOCK_NOSWITCH(p);
DROP_GIANT_NOSWITCH(); DROP_GIANT_NOSWITCH();
@ -1519,8 +1519,7 @@ issignal(p)
/* /*
* Put the argument process into the stopped state and notify the parent * Put the argument process into the stopped state and notify the parent
* via wakeup. Signals are handled elsewhere. The process must not be * via wakeup. Signals are handled elsewhere. The process must not be
* on the run queue. Must be called with at least a shared hold of the * on the run queue. Must be called with the proc p locked.
* proctree lock.
*/ */
void void
stop(p) stop(p)