diff options
author | Philip Guenther <guenther@cvs.openbsd.org> | 2013-04-01 01:07:35 +0000 |
---|---|---|
committer | Philip Guenther <guenther@cvs.openbsd.org> | 2013-04-01 01:07:35 +0000 |
commit | 00651a7ec096a1f3120d173f5e237172874b269e (patch) | |
tree | a2769ced25ae28dd37aa6d34733a50ff225b889b /sys/kern | |
parent | f716b184b26327fd97f800b6447a9c668023fc50 (diff) |
Make setrlimit() return EINVAL if rlim_cur > rlim_max, per POSIX.
Use limfree() instead of decrementing the reference counter directly.
ok kettenis@
Diffstat (limited to 'sys/kern')
-rw-r--r-- | sys/kern/kern_resource.c | 9 |
1 files changed, 4 insertions, 5 deletions
diff --git a/sys/kern/kern_resource.c b/sys/kern/kern_resource.c index 995b3db15ef..ea4f8bf512b 100644 --- a/sys/kern/kern_resource.c +++ b/sys/kern/kern_resource.c @@ -1,4 +1,4 @@ -/* $OpenBSD: kern_resource.c,v 1.40 2012/04/10 15:50:52 guenther Exp $ */ +/* $OpenBSD: kern_resource.c,v 1.41 2013/04/01 01:07:34 guenther Exp $ */ /* $NetBSD: kern_resource.c,v 1.38 1996/10/23 07:19:38 matthias Exp $ */ /*- @@ -236,12 +236,11 @@ dosetrlimit(struct proc *p, u_int which, struct rlimit *limp) rlim_t maxlim; int error; - if (which >= RLIM_NLIMITS) + if (which >= RLIM_NLIMITS || limp->rlim_cur > limp->rlim_max) return (EINVAL); alimp = &p->p_rlimit[which]; - if (limp->rlim_cur > alimp->rlim_max || - limp->rlim_max > alimp->rlim_max) + if (limp->rlim_max > alimp->rlim_max) if ((error = suser(p, 0)) != 0) return (error); if (p->p_p->ps_limit->p_refcnt > 1) { @@ -249,7 +248,7 @@ dosetrlimit(struct proc *p, u_int which, struct rlimit *limp) /* limcopy() can sleep, so copy before decrementing refcnt */ p->p_p->ps_limit = limcopy(l); - l->p_refcnt--; + limfree(l); alimp = &p->p_rlimit[which]; } |