Skip to content

Commit

Permalink
FreeBSD: catch up to 1400068
Browse files Browse the repository at this point in the history
  • Loading branch information
mjguzik committed Sep 17, 2022
1 parent 48cf170 commit 8e8904e
Showing 1 changed file with 22 additions and 1 deletion.
23 changes: 22 additions & 1 deletion module/os/freebsd/zfs/zfs_vnops_os.c
Original file line number Diff line number Diff line change
Expand Up @@ -971,13 +971,17 @@ zfs_lookup(vnode_t *dvp, const char *nm, vnode_t **vpp,
case RENAME:
if (error == ENOENT) {
error = EJUSTRETURN;
#if __FreeBSD_version < 1400068
cnp->cn_flags |= SAVENAME;
#endif
break;
}
zfs_fallthrough;
case DELETE:
#if __FreeBSD_version < 1400068
if (error == 0)
cnp->cn_flags |= SAVENAME;
#endif
break;
}
}
Expand Down Expand Up @@ -1327,7 +1331,10 @@ zfs_lookup_internal(znode_t *dzp, const char *name, vnode_t **vpp,
cnp->cn_nameptr = __DECONST(char *, name);
cnp->cn_namelen = strlen(name);
cnp->cn_nameiop = nameiop;
cnp->cn_flags = ISLASTCN | SAVENAME;
cnp->cn_flags = ISLASTCN;
#if __FreeBSD_version < 1400068
cnp->cn_flags |= SAVENAME;
#endif
cnp->cn_lkflags = LK_EXCLUSIVE | LK_RETRY;
cnp->cn_cred = kcred;
#if __FreeBSD_version < 1400037
Expand Down Expand Up @@ -4626,7 +4633,9 @@ zfs_freebsd_create(struct vop_create_args *ap)
znode_t *zp = NULL;
int rc, mode;

#if __FreeBSD_version < 1400068
ASSERT(cnp->cn_flags & SAVENAME);
#endif

vattr_init_mask(vap);
mode = vap->va_mode & ALLPERMS;
Expand Down Expand Up @@ -4656,7 +4665,9 @@ static int
zfs_freebsd_remove(struct vop_remove_args *ap)
{

#if __FreeBSD_version < 1400068
ASSERT(ap->a_cnp->cn_flags & SAVENAME);
#endif

return (zfs_remove_(ap->a_dvp, ap->a_vp, ap->a_cnp->cn_nameptr,
ap->a_cnp->cn_cred));
Expand All @@ -4678,7 +4689,9 @@ zfs_freebsd_mkdir(struct vop_mkdir_args *ap)
znode_t *zp = NULL;
int rc;

#if __FreeBSD_version < 1400068
ASSERT(ap->a_cnp->cn_flags & SAVENAME);
#endif

vattr_init_mask(vap);
*ap->a_vpp = NULL;
Expand All @@ -4704,7 +4717,9 @@ zfs_freebsd_rmdir(struct vop_rmdir_args *ap)
{
struct componentname *cnp = ap->a_cnp;

#if __FreeBSD_version < 1400068
ASSERT(cnp->cn_flags & SAVENAME);
#endif

return (zfs_rmdir_(ap->a_dvp, ap->a_vp, cnp->cn_nameptr, cnp->cn_cred));
}
Expand Down Expand Up @@ -4958,8 +4973,10 @@ zfs_freebsd_rename(struct vop_rename_args *ap)
vnode_t *tvp = ap->a_tvp;
int error;

#if __FreeBSD_version < 1400068
ASSERT(ap->a_fcnp->cn_flags & (SAVENAME|SAVESTART));
ASSERT(ap->a_tcnp->cn_flags & (SAVENAME|SAVESTART));
#endif

error = zfs_do_rename(fdvp, &fvp, ap->a_fcnp, tdvp, &tvp,
ap->a_tcnp, ap->a_fcnp->cn_cred);
Expand Down Expand Up @@ -4995,7 +5012,9 @@ zfs_freebsd_symlink(struct vop_symlink_args *ap)
#endif
int rc;

#if __FreeBSD_version < 1400068
ASSERT(cnp->cn_flags & SAVENAME);
#endif

vap->va_type = VLNK; /* FreeBSD: Syscall only sets va_mode. */
vattr_init_mask(vap);
Expand Down Expand Up @@ -5089,7 +5108,9 @@ zfs_freebsd_link(struct vop_link_args *ap)
if (tdvp->v_mount != vp->v_mount)
return (EXDEV);

#if __FreeBSD_version < 1400068
ASSERT(cnp->cn_flags & SAVENAME);
#endif

return (zfs_link(VTOZ(tdvp), VTOZ(vp),
cnp->cn_nameptr, cnp->cn_cred, 0));
Expand Down

0 comments on commit 8e8904e

Please sign in to comment.