diff options
| author | John Baldwin <jhb@FreeBSD.org> | 2000-12-02 01:32:51 +0000 |
|---|---|---|
| committer | John Baldwin <jhb@FreeBSD.org> | 2000-12-02 01:32:51 +0000 |
| commit | 0ebabc93a454467be57821c02ac5182e1bb34699 (patch) | |
| tree | e0485694c6bebbb0c0ec0f54c58628afedc6c3cb /sys/kern/sys_process.c | |
| parent | 3cd59d7b9c74c4bfb7e5559b4fd3652020a2e473 (diff) | |
Notes
Diffstat (limited to 'sys/kern/sys_process.c')
| -rw-r--r-- | sys/kern/sys_process.c | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/sys/kern/sys_process.c b/sys/kern/sys_process.c index 533ba71f51d2..c9abad45c604 100644 --- a/sys/kern/sys_process.c +++ b/sys/kern/sys_process.c @@ -280,8 +280,12 @@ ptrace(curp, uap) return EBUSY; /* not currently stopped */ - if (p->p_stat != SSTOP || (p->p_flag & P_WAITED) == 0) + mtx_enter(&sched_lock, MTX_SPIN); + if (p->p_stat != SSTOP || (p->p_flag & P_WAITED) == 0) { + mtx_exit(&sched_lock, MTX_SPIN); return EBUSY; + } + mtx_exit(&sched_lock, MTX_SPIN); /* OK */ break; @@ -363,11 +367,17 @@ ptrace(curp, uap) sendsig: /* deliver or queue signal */ s = splhigh(); + mtx_enter(&sched_lock, MTX_SPIN); if (p->p_stat == SSTOP) { p->p_xstat = uap->data; setrunnable(p); - } else if (uap->data) { - psignal(p, uap->data); + mtx_exit(&sched_lock, MTX_SPIN); + } else { + mtx_exit(&sched_lock, MTX_SPIN); + if (uap->data) { + mtx_assert(&Giant, MA_OWNED); + psignal(p, uap->data); + } } splx(s); return 0; |
