diff options
author | Sebastien Marie <semarie@cvs.openbsd.org> | 2015-10-25 11:09:29 +0000 |
---|---|---|
committer | Sebastien Marie <semarie@cvs.openbsd.org> | 2015-10-25 11:09:29 +0000 |
commit | 2460b648e129fbb65573c6f408bf97062f5af570 (patch) | |
tree | fe076210cd661a2214021bd2e9d349c593520397 /sys/kern | |
parent | 38f2c7db063b8692449987572feea6fe7b2870c4 (diff) |
reorder some checks in pledge_namei() in order to properly work.
mainly move read/write whitelisted paths that should be *before* checking if
you have PLEDGE_WPATH.
with and ok deraadt@
Diffstat (limited to 'sys/kern')
-rw-r--r-- | sys/kern/kern_pledge.c | 42 |
1 files changed, 21 insertions, 21 deletions
diff --git a/sys/kern/kern_pledge.c b/sys/kern/kern_pledge.c index fd1a9aeb732..1ca6490de70 100644 --- a/sys/kern/kern_pledge.c +++ b/sys/kern/kern_pledge.c @@ -1,4 +1,4 @@ -/* $OpenBSD: kern_pledge.c,v 1.71 2015/10/25 10:30:58 deraadt Exp $ */ +/* $OpenBSD: kern_pledge.c,v 1.72 2015/10/25 11:09:28 semarie Exp $ */ /* * Copyright (c) 2015 Nicholas Marriott <nicm@openbsd.org> @@ -557,11 +557,30 @@ pledge_namei(struct proc *p, char *origpath) (p->p_p->ps_pledge & PLEDGE_EXEC)) return (0); + /* Whitelisted read/write paths */ + switch (p->p_pledge_syscall) { + case SYS_open: + /* daemon(3) or other such functions */ + if ((p->p_pledgenote & ~(TMN_RPATH | TMN_WPATH)) == 0 && + strcmp(path, "/dev/null") == 0) { + return (0); + } + + /* readpassphrase(3), getpw*(3) */ + if ((p->p_p->ps_pledge & (PLEDGE_TTY | PLEDGE_GETPW)) && + (p->p_pledgenote & ~(TMN_RPATH | TMN_WPATH)) == 0 && + strcmp(path, "/dev/tty") == 0) { + return (0); + } + break; + } + + /* ensure PLEDGE_WPATH request for doing write */ if ((p->p_pledgenote & TMN_WPATH) && (p->p_p->ps_pledge & PLEDGE_WPATH) == 0) return (pledge_fail(p, EPERM, PLEDGE_WPATH)); - /* Read-only paths used occasionally by libc */ + /* Whitelisted read-only paths */ switch (p->p_pledge_syscall) { case SYS_access: /* tzset() needs this. */ @@ -570,12 +589,6 @@ pledge_namei(struct proc *p, char *origpath) return (0); break; case SYS_open: - /* daemon(3) or other such functions */ - if ((p->p_pledgenote & ~(TMN_RPATH | TMN_WPATH)) == 0 && - strcmp(path, "/dev/null") == 0) { - return (0); - } - /* getpw* and friends need a few files */ if ((p->p_pledgenote == TMN_RPATH) && (p->p_p->ps_pledge & PLEDGE_GETPW)) { @@ -587,13 +600,6 @@ pledge_namei(struct proc *p, char *origpath) return (0); } - /* "YP server for domain %s not responding, still trying" */ - if ((p->p_p->ps_pledge & PLEDGE_GETPW) && - (p->p_pledgenote & ~(TMN_RPATH | TMN_WPATH)) == 0 && - strcmp(path, "/dev/tty") == 0) { - return (0); - } - /* DNS needs /etc/{resolv.conf,hosts,services}. */ if ((p->p_pledgenote == TMN_RPATH) && (p->p_p->ps_pledge & PLEDGE_DNS)) { @@ -632,12 +638,6 @@ pledge_namei(struct proc *p, char *origpath) strcmp(path + strlen(path) - 9, "/libc.cat") == 0) return (0); - /* Allow opening r/w on /dev/tty when "tty" is specified. */ - if ((p->p_p->ps_pledge & PLEDGE_TTY) && - (p->p_pledgenote & ~(TMN_RPATH | TMN_WPATH)) == 0 && - strcmp(path, "/dev/tty") == 0) { - return (0); - } break; case SYS_readlink: /* Allow /etc/malloc.conf for malloc(3). */ |