diff options
| author | 2008-10-31 17:15:29 +0000 | |
|---|---|---|
| committer | 2008-10-31 17:15:29 +0000 | |
| commit | 270a889ebbe198288b6616fbdb15a3a92a2376e3 (patch) | |
| tree | 1a7f94574fbf06367505ca47455d6b05b91db13d /sys/kern/kern_exit.c | |
| parent | checkdirs() walks allproc and calls sleeping functions if directories have (diff) | |
| download | wireguard-openbsd-270a889ebbe198288b6616fbdb15a3a92a2376e3.tar.xz wireguard-openbsd-270a889ebbe198288b6616fbdb15a3a92a2376e3.zip | |
kern_sysctl.c
Diffstat (limited to 'sys/kern/kern_exit.c')
| -rw-r--r-- | sys/kern/kern_exit.c | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/sys/kern/kern_exit.c b/sys/kern/kern_exit.c index d3396e2e8dc..9a35b7d4fa5 100644 --- a/sys/kern/kern_exit.c +++ b/sys/kern/kern_exit.c @@ -1,4 +1,4 @@ -/* $OpenBSD: kern_exit.c,v 1.77 2008/10/30 17:09:13 deraadt Exp $ */ +/* $OpenBSD: kern_exit.c,v 1.78 2008/10/31 17:15:30 deraadt Exp $ */ /* $NetBSD: kern_exit.c,v 1.39 1996/04/22 01:38:25 christos Exp $ */ /* @@ -225,8 +225,12 @@ exit1(struct proc *p, int rv, int flags) * release trace file */ p->p_traceflag = 0; /* don't trace the vrele() */ - if (p->p_tracep) - ktrsettracevnode(p, NULL); + if (p->p_tracep) { + struct vnode *vp = p->p_tracep; + if (ktrsettracevnode(p, NULL) == 1) + vrele(vp); + } + #endif #if NSYSTRACE > 0 if (ISSET(p->p_flag, P_SYSTRACE)) |
