diff options
author | phk <phk@FreeBSD.org> | 1997-09-10 19:47:37 +0000 |
---|---|---|
committer | phk <phk@FreeBSD.org> | 1997-09-10 19:47:37 +0000 |
commit | 8e20f7ec0eb58e4adf6aaa2f3a9ca01a9bce42c4 (patch) | |
tree | 62aa8cd1162b54cef39562b09199fb34b36110b5 | |
parent | 577767a73abf60545bf417da9734d3351f4b3e5a (diff) | |
download | FreeBSD-src-8e20f7ec0eb58e4adf6aaa2f3a9ca01a9bce42c4.zip FreeBSD-src-8e20f7ec0eb58e4adf6aaa2f3a9ca01a9bce42c4.tar.gz |
Update the comment and remove checks now done centrally.
-rw-r--r-- | sys/ufs/ufs/ufs_lookup.c | 32 |
1 files changed, 16 insertions, 16 deletions
diff --git a/sys/ufs/ufs/ufs_lookup.c b/sys/ufs/ufs/ufs_lookup.c index 1762fb0..e0eb989 100644 --- a/sys/ufs/ufs/ufs_lookup.c +++ b/sys/ufs/ufs/ufs_lookup.c @@ -36,7 +36,7 @@ * SUCH DAMAGE. * * @(#)ufs_lookup.c 8.15 (Berkeley) 6/16/95 - * $Id: ufs_lookup.c,v 1.15 1997/08/26 07:32:51 phk Exp $ + * $Id: ufs_lookup.c,v 1.16 1997/09/02 20:06:58 bde Exp $ */ #include <sys/param.h> @@ -78,11 +78,23 @@ int dirchk = 0; * be "."., but the caller must check to ensure it does an vrele and vput * instead of two vputs. * - * Overall outline of ufs_lookup: + * This routine is actually used as VOP_CACHEDLOOKUP method, and the + * filesystem employs the generic vfs_cache_lookup() as VOP_LOOKUP + * method. * + * vfs_cache_lookup() performs the following for us: + * check that it is a directory * check accessibility of directory - * look for name in cache, if found, then if at end of path - * and deleting or creating, drop it, else return name + * check for modification attempts on read-only mounts + * if name found in cache + * if at end of path and deleting or creating + * drop it + * else + * return name. + * return VOP_CACHEDLOOKUP() + * + * Overall outline of ufs_lookup: + * * search for name in directory, to found or notfound * notfound: * if creating, return locked directory, leaving info on available slots @@ -138,18 +150,6 @@ ufs_lookup(ap) wantparent = flags & (LOCKPARENT|WANTPARENT); /* - * Check accessiblity of directory. - */ - if ((dp->i_mode & IFMT) != IFDIR) - return (ENOTDIR); - error = VOP_ACCESS(vdp, VEXEC, cred, cnp->cn_proc); - if (error) - return (error); - if ((flags & ISLASTCN) && (vdp->v_mount->mnt_flag & MNT_RDONLY) && - (cnp->cn_nameiop == DELETE || cnp->cn_nameiop == RENAME)) - return (EROFS); - - /* * We now have a segment name to search for, and a directory to search. * * Suppress search for slots unless creating |