diff options
author | Sebastien Marie <semarie@cvs.openbsd.org> | 2021-03-20 11:26:08 +0000 |
---|---|---|
committer | Sebastien Marie <semarie@cvs.openbsd.org> | 2021-03-20 11:26:08 +0000 |
commit | 2a3651e28c03487e065a7e87eef46001ac59d986 (patch) | |
tree | a3b87d20cc1e571c84837d37d5dba346e87d4364 /sys/kern/vfs_lookup.c | |
parent | e0461888e48c4d4978f535c880dcf7e63208257d (diff) |
namei: reorganize a bit the error path for simples cases
- move 'fail' label to end of function (instead of using the first
if-condition)
- merge the most simples error code paths idioms from 'cleanup+return'
to 'goto-fail'
ok mpi@
Diffstat (limited to 'sys/kern/vfs_lookup.c')
-rw-r--r-- | sys/kern/vfs_lookup.c | 40 |
1 files changed, 17 insertions, 23 deletions
diff --git a/sys/kern/vfs_lookup.c b/sys/kern/vfs_lookup.c index da3048f0f18..34345bbb417 100644 --- a/sys/kern/vfs_lookup.c +++ b/sys/kern/vfs_lookup.c @@ -1,4 +1,4 @@ -/* $OpenBSD: vfs_lookup.c,v 1.83 2019/09/11 15:01:40 beck Exp $ */ +/* $OpenBSD: vfs_lookup.c,v 1.84 2021/03/20 11:26:07 semarie Exp $ */ /* $NetBSD: vfs_lookup.c,v 1.17 1996/02/09 19:00:59 christos Exp $ */ /* @@ -157,12 +157,8 @@ namei(struct nameidata *ndp) if (error == 0 && ndp->ni_pathlen == 1) error = ENOENT; - if (error) { -fail: - pool_put(&namei_pool, cnp->cn_pnbuf); - ndp->ni_vp = NULL; - return (error); - } + if (error) + goto fail; #ifdef KTRACE if (KTRPOINT(cnp->cn_proc, KTR_NAMEI)) @@ -222,14 +218,14 @@ fail: } else { struct file *fp = fd_getfile(fdp, ndp->ni_dirfd); if (fp == NULL) { - pool_put(&namei_pool, cnp->cn_pnbuf); - return (EBADF); + error = EBADF; + goto fail; } dp = (struct vnode *)fp->f_data; if (fp->f_type != DTYPE_VNODE || dp->v_type != VDIR) { FRELE(fp, p); - pool_put(&namei_pool, cnp->cn_pnbuf); - return (ENOTDIR); + error = ENOTDIR; + goto fail; } vref(dp); unveil_start_relative(p, ndp, dp); @@ -239,23 +235,21 @@ fail: for (;;) { if (!dp->v_mount) { /* Give up if the directory is no longer mounted */ - pool_put(&namei_pool, cnp->cn_pnbuf); vrele(dp); - ndp->ni_vp = NULL; - return (ENOENT); + error = ENOENT; + goto fail; } + cnp->cn_nameptr = cnp->cn_pnbuf; ndp->ni_startdir = dp; - if ((error = vfs_lookup(ndp)) != 0) { - pool_put(&namei_pool, cnp->cn_pnbuf); - return (error); - } + if ((error = vfs_lookup(ndp)) != 0) + goto fail; + /* * If not a symbolic link, return search result. */ if ((cnp->cn_flags & ISSYMLINK) == 0) { if ((error = unveil_check_final(p, ndp))) { - pool_put(&namei_pool, cnp->cn_pnbuf); if ((cnp->cn_flags & LOCKPARENT) && (cnp->cn_flags & ISLASTCN) && (ndp->ni_vp != ndp->ni_dvp)) @@ -266,14 +260,13 @@ fail: else vrele(ndp->ni_vp); } - ndp->ni_vp = NULL; - return (error); + goto fail; } if ((cnp->cn_flags & (SAVENAME | SAVESTART)) == 0) pool_put(&namei_pool, cnp->cn_pnbuf); else cnp->cn_flags |= HASBUF; - return(0); + return (0); } if ((cnp->cn_flags & LOCKPARENT) && (cnp->cn_flags & ISLASTCN)) VOP_UNLOCK(ndp->ni_dvp); @@ -337,9 +330,10 @@ badlink: component_pop(cnp); } } - pool_put(&namei_pool, cnp->cn_pnbuf); vrele(ndp->ni_dvp); vput(ndp->ni_vp); +fail: + pool_put(&namei_pool, cnp->cn_pnbuf); ndp->ni_vp = NULL; return (error); } |