Date: Mon, 18 Sep 1995 14:05:08 -0700 (MST) From: Terry Lambert <terry@lambert.org> To: julian@ref.tfs.com (Julian Elischer) Cc: hackers@FreeBSD.ORG Subject: Re: suspect code in 'unlink' syscall. Message-ID: <199509182105.OAA08619@phaeton.artisoft.com> In-Reply-To: <199509180750.AAA01170@ref.tfs.com> from "Julian Elischer" at Sep 18, 95 00:50:32 am
next in thread | previous in thread | raw e-mail | index | archive | help
> looking at 'unlink (2)' > I see, > if (vp->v_type != VDIR || > (error = suser(p->p_ucred, &p->p_acflag)) == 0) { > /* > * The root of a mounted filesystem cannot be deleted. > */ > if (vp->v_flag & VROOT) > error = EBUSY; > else > (void) vnode_pager_uncache(vp); > } > > I translate this as: > "if it's not a DIR, or we are root", > check if we are deleteing the > root of an FS, > if not, flush cache...... > > now, if we were NOT root, and it IS a dir...... (normal...) > > can we delete it? > I'm about to try this.. > if you dont hear from me, the building exploded... Invert the test. I made this mod some time ago: if( ( error = suser(p->p_ucred, &p->p_acflag)) == 0 || vp->v_type != VDIR) { This way, the error code will be set to EPERM if you are not root and the followon code will not be executed. Terry Lambert terry@lambert.org --- Any opinions in this posting are my own and not those of my present or previous employers.
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?199509182105.OAA08619>