diff options
author | kib <kib@FreeBSD.org> | 2010-05-10 15:18:03 +0000 |
---|---|---|
committer | kib <kib@FreeBSD.org> | 2010-05-10 15:18:03 +0000 |
commit | 0415e01577537dd559eca69bbc79a158cd6ad021 (patch) | |
tree | d23fbda8b62e2f7c1bc7ebca863d0d239ce1c710 /sys/fs/procfs | |
parent | 58ebe905c9801ed65df6e23bcb2efb9e8494dc93 (diff) | |
download | FreeBSD-src-0415e01577537dd559eca69bbc79a158cd6ad021.zip FreeBSD-src-0415e01577537dd559eca69bbc79a158cd6ad021.tar.gz |
For detach procfs ctl command, also clear P_STOPPED_TRACE process stop
flag, and for each thread, TDB_SUSPEND debug flag, same as it is done by
exit1() for orphaned debugee.
Approved by: des (procfs maintainer)
MFC after: 1 week
Diffstat (limited to 'sys/fs/procfs')
-rw-r--r-- | sys/fs/procfs/procfs_ctl.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/sys/fs/procfs/procfs_ctl.c b/sys/fs/procfs/procfs_ctl.c index ca227e8..69e40a0 100644 --- a/sys/fs/procfs/procfs_ctl.c +++ b/sys/fs/procfs/procfs_ctl.c @@ -110,6 +110,7 @@ static int procfs_control(struct thread *td, struct proc *p, int op) { int error = 0; + struct thread *temp; /* * Attach - attaches the target process for debugging @@ -212,10 +213,12 @@ out: } /* not being traced any more */ - p->p_flag &= ~P_TRACED; + p->p_flag &= ~(P_TRACED | P_STOPPED_TRACE); /* remove pending SIGTRAP, else the process will die */ sigqueue_delete_proc(p, SIGTRAP); + FOREACH_THREAD_IN_PROC(p, temp) + temp->td_dbgflags &= ~TDB_SUSPEND; PROC_UNLOCK(p); /* give process back to original parent */ |