1
0
mirror of https://git.FreeBSD.org/src.git synced 2025-01-18 15:30:21 +00:00

- Lock proctree_lock instead of pgrpsess_lock.

- Exclusively lock proctree_lock while calling leavepgrp().
This commit is contained in:
John Baldwin 2002-04-16 17:04:21 +00:00
parent f089b57070
commit ea97757a54
Notes: svn2git 2020-12-20 02:59:44 +00:00
svn path=/head/; revision=94858
2 changed files with 8 additions and 8 deletions

View File

@ -1337,13 +1337,13 @@ svr4_sys_waitsys(td, uap)
* Finally finished with old proc entry.
* Unlink it from its process group and free it.
*/
sx_xlock(&proctree_lock);
leavepgrp(q);
sx_xlock(&allproc_lock);
LIST_REMOVE(q, p_list); /* off zombproc */
sx_xunlock(&allproc_lock);
sx_xlock(&proctree_lock);
LIST_REMOVE(q, p_sibling);
sx_xunlock(&proctree_lock);

View File

@ -231,7 +231,7 @@ exit1(td, rv)
vm->vm_freer = p;
}
PGRPSESS_XLOCK();
sx_xlock(&proctree_lock);
if (SESS_LEADER(p)) {
register struct session *sp;
@ -251,9 +251,9 @@ exit1(td, rv)
PGRP_UNLOCK(sp->s_ttyp->t_pgrp);
}
/* XXX tp should be locked. */
PGRPSESS_XUNLOCK();
sx_xunlock(&proctree_lock);
(void) ttywait(tp);
PGRPSESS_XLOCK();
sx_xlock(&proctree_lock);
/*
* The tty could have been revoked
* if we blocked.
@ -263,10 +263,10 @@ exit1(td, rv)
SESS_LOCK(p->p_session);
sp->s_ttyvp = NULL;
SESS_UNLOCK(p->p_session);
PGRPSESS_XUNLOCK();
sx_xunlock(&proctree_lock);
VOP_REVOKE(ttyvp, REVOKEALL);
PGRPSESS_XLOCK();
vrele(ttyvp);
sx_xlock(&proctree_lock);
}
}
if (sp->s_ttyvp) {
@ -287,7 +287,7 @@ exit1(td, rv)
SESS_UNLOCK(p->p_session);
}
fixjobc(p, p->p_pgrp, 0);
PGRPSESS_XUNLOCK();
sx_xunlock(&proctree_lock);
(void)acct_process(td);
#ifdef KTRACE
/*
@ -619,13 +619,13 @@ wait1(td, uap, compat)
* Finally finished with old proc entry.
* Unlink it from its process group and free it.
*/
sx_xlock(&proctree_lock);
leavepgrp(p);
sx_xlock(&allproc_lock);
LIST_REMOVE(p, p_list); /* off zombproc */
sx_xunlock(&allproc_lock);
sx_xlock(&proctree_lock);
LIST_REMOVE(p, p_sibling);
sx_xunlock(&proctree_lock);