summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorkib <kib@FreeBSD.org>2010-05-17 08:15:04 +0000
committerkib <kib@FreeBSD.org>2010-05-17 08:15:04 +0000
commit0af2e00748bcb4e5455492b72420d3a2c11386a3 (patch)
tree80fb401bd30ea8529c903273e2987941fc74c2d8
parent5742992beacc27af315742b873e7ec114d3a2607 (diff)
downloadFreeBSD-src-0af2e00748bcb4e5455492b72420d3a2c11386a3.zip
FreeBSD-src-0af2e00748bcb4e5455492b72420d3a2c11386a3.tar.gz
MFC r207848:
The thread_unsuspend() requires both process mutex and process spinlock locked. Postpone the process unlock till the thread_unsuspend() is called.
-rw-r--r--sys/fs/procfs/procfs_ctl.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/sys/fs/procfs/procfs_ctl.c b/sys/fs/procfs/procfs_ctl.c
index 69e40a0..5980ce1 100644
--- a/sys/fs/procfs/procfs_ctl.c
+++ b/sys/fs/procfs/procfs_ctl.c
@@ -236,7 +236,6 @@ out:
PROC_LOCK(p);
p->p_oppid = 0;
p->p_flag &= ~P_WAITED; /* XXX ? */
- PROC_UNLOCK(p);
sx_xunlock(&proctree_lock);
wakeup(td->td_proc); /* XXX for CTL_WAIT below ? */
@@ -249,9 +248,10 @@ out:
*/
case PROCFS_CTL_STEP:
error = proc_sstep(FIRST_THREAD_IN_PROC(p));
- PROC_UNLOCK(p);
- if (error)
+ if (error) {
+ PROC_UNLOCK(p);
return (error);
+ }
break;
/*
@@ -260,7 +260,6 @@ out:
*/
case PROCFS_CTL_RUN:
p->p_flag &= ~P_STOPPED_SIG; /* this uses SIGSTOP */
- PROC_UNLOCK(p);
break;
/*
@@ -292,6 +291,7 @@ out:
PROC_SLOCK(p);
thread_unsuspend(p); /* If it can run, let it do so. */
PROC_SUNLOCK(p);
+ PROC_UNLOCK(p);
return (0);
}
OpenPOWER on IntegriCloud