diff options
author | 1998-06-09 17:23:04 +0000 | |
---|---|---|
committer | 1998-06-09 17:23:04 +0000 | |
commit | c98206eec1cf7c800da6c089995dfdf151683de9 (patch) | |
tree | 48ff7029bcdc8d653f97e8ef647686ecf816b015 /sys/kern/kern_exec.c | |
parent | there is no such thing as dprintf'' (diff) | |
download | wireguard-openbsd-c98206eec1cf7c800da6c089995dfdf151683de9.tar.xz wireguard-openbsd-c98206eec1cf7c800da6c089995dfdf151683de9.zip |
if we are being ptraced, do not permit execve of an immutable binary
Diffstat (limited to 'sys/kern/kern_exec.c')
-rw-r--r-- | sys/kern/kern_exec.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/sys/kern/kern_exec.c b/sys/kern/kern_exec.c index 99966d022ba..8e198fc5105 100644 --- a/sys/kern/kern_exec.c +++ b/sys/kern/kern_exec.c @@ -1,4 +1,4 @@ -/* $OpenBSD: kern_exec.c,v 1.17 1998/02/20 14:45:16 niklas Exp $ */ +/* $OpenBSD: kern_exec.c,v 1.18 1998/06/09 17:23:04 deraadt Exp $ */ /* $NetBSD: kern_exec.c,v 1.75 1996/02/09 18:59:28 christos Exp $ */ /*- @@ -127,6 +127,8 @@ check_exec(p, epp) if ((vp->v_mount->mnt_flag & MNT_NOSUID) || (p->p_flag & P_TRACED) || p->p_fd->fd_refcnt > 1) epp->ep_vap->va_mode &= ~(VSUID | VSGID); + if (p->p_flag & P_TRACED && (epp->ep_vap->va_flags & IMMUTABLE)) + goto bad1; /* check access. for root we have to see if any exec bit on */ if ((error = VOP_ACCESS(vp, VEXEC, p->p_ucred, p)) != 0) |