svn commit: r345972 - in stable/12/sys: cddl/contrib/opensolaris/uts/common/fs/zfs fs/nandfs fs/nfsclient kern ufs/ufs
Simon J. Gerraty
sjg at FreeBSD.org
Fri Apr 5 23:34:48 UTC 2019
Author: sjg
Date: Fri Apr 5 23:34:46 2019
New Revision: 345972
URL: https://svnweb.freebsd.org/changeset/base/345972
Log:
Add _PC_ACL_* to vop_stdpathconf
This avoid EINVAL from tmpfs etc.
Merge of r345024
Reviewed by: kib
Differential Revision: https://reviews.freebsd.org/D19512
Modified:
stable/12/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zfs_ctldir.c
stable/12/sys/fs/nandfs/nandfs_vnops.c
stable/12/sys/fs/nfsclient/nfs_clvnops.c
stable/12/sys/kern/vfs_default.c
stable/12/sys/ufs/ufs/ufs_vnops.c
Modified: stable/12/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zfs_ctldir.c
==============================================================================
--- stable/12/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zfs_ctldir.c Fri Apr 5 22:45:43 2019 (r345971)
+++ stable/12/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zfs_ctldir.c Fri Apr 5 23:34:46 2019 (r345972)
@@ -755,10 +755,6 @@ zfsctl_common_pathconf(ap)
*ap->a_retval = (int)SPA_MINBLOCKSIZE;
return (0);
- case _PC_ACL_EXTENDED:
- *ap->a_retval = 0;
- return (0);
-
case _PC_ACL_NFS4:
*ap->a_retval = 1;
return (0);
Modified: stable/12/sys/fs/nandfs/nandfs_vnops.c
==============================================================================
--- stable/12/sys/fs/nandfs/nandfs_vnops.c Fri Apr 5 22:45:43 2019 (r345971)
+++ stable/12/sys/fs/nandfs/nandfs_vnops.c Fri Apr 5 23:34:46 2019 (r345972)
@@ -2258,9 +2258,6 @@ nandfs_pathconf(struct vop_pathconf_args *ap)
case _PC_NO_TRUNC:
*ap->a_retval = 1;
break;
- case _PC_ACL_EXTENDED:
- *ap->a_retval = 0;
- break;
case _PC_ALLOC_SIZE_MIN:
*ap->a_retval = ap->a_vp->v_mount->mnt_stat.f_bsize;
break;
Modified: stable/12/sys/fs/nfsclient/nfs_clvnops.c
==============================================================================
--- stable/12/sys/fs/nfsclient/nfs_clvnops.c Fri Apr 5 22:45:43 2019 (r345971)
+++ stable/12/sys/fs/nfsclient/nfs_clvnops.c Fri Apr 5 23:34:46 2019 (r345972)
@@ -3485,9 +3485,6 @@ nfs_pathconf(struct vop_pathconf_args *ap)
case _PC_NO_TRUNC:
*ap->a_retval = pc.pc_notrunc;
break;
- case _PC_ACL_EXTENDED:
- *ap->a_retval = 0;
- break;
case _PC_ACL_NFS4:
if (NFS_ISV4(vp) && nfsrv_useacl != 0 && attrflag != 0 &&
NFSISSET_ATTRBIT(&nfsva.na_suppattr, NFSATTRBIT_ACL))
@@ -3500,9 +3497,6 @@ nfs_pathconf(struct vop_pathconf_args *ap)
*ap->a_retval = ACL_MAX_ENTRIES;
else
*ap->a_retval = 3;
- break;
- case _PC_MAC_PRESENT:
- *ap->a_retval = 0;
break;
case _PC_PRIO_IO:
*ap->a_retval = 0;
Modified: stable/12/sys/kern/vfs_default.c
==============================================================================
--- stable/12/sys/kern/vfs_default.c Fri Apr 5 22:45:43 2019 (r345971)
+++ stable/12/sys/kern/vfs_default.c Fri Apr 5 23:34:46 2019 (r345972)
@@ -482,6 +482,13 @@ vop_stdpathconf(ap)
case _PC_PATH_MAX:
*ap->a_retval = PATH_MAX;
return (0);
+ case _PC_ACL_EXTENDED:
+ case _PC_ACL_NFS4:
+ case _PC_CAP_PRESENT:
+ case _PC_INF_PRESENT:
+ case _PC_MAC_PRESENT:
+ *ap->a_retval = 0;
+ return (0);
default:
return (EINVAL);
}
Modified: stable/12/sys/ufs/ufs/ufs_vnops.c
==============================================================================
--- stable/12/sys/ufs/ufs/ufs_vnops.c Fri Apr 5 22:45:43 2019 (r345971)
+++ stable/12/sys/ufs/ufs/ufs_vnops.c Fri Apr 5 23:34:46 2019 (r345972)
@@ -2421,28 +2421,20 @@ ufs_pathconf(ap)
case _PC_NO_TRUNC:
*ap->a_retval = 1;
break;
- case _PC_ACL_EXTENDED:
#ifdef UFS_ACL
+ case _PC_ACL_EXTENDED:
if (ap->a_vp->v_mount->mnt_flag & MNT_ACLS)
*ap->a_retval = 1;
else
*ap->a_retval = 0;
-#else
- *ap->a_retval = 0;
-#endif
break;
-
case _PC_ACL_NFS4:
-#ifdef UFS_ACL
if (ap->a_vp->v_mount->mnt_flag & MNT_NFS4ACLS)
*ap->a_retval = 1;
else
*ap->a_retval = 0;
-#else
- *ap->a_retval = 0;
-#endif
break;
-
+#endif
case _PC_ACL_PATH_MAX:
#ifdef UFS_ACL
if (ap->a_vp->v_mount->mnt_flag & (MNT_ACLS | MNT_NFS4ACLS))
@@ -2453,16 +2445,14 @@ ufs_pathconf(ap)
*ap->a_retval = 3;
#endif
break;
- case _PC_MAC_PRESENT:
#ifdef MAC
+ case _PC_MAC_PRESENT:
if (ap->a_vp->v_mount->mnt_flag & MNT_MULTILABEL)
*ap->a_retval = 1;
else
*ap->a_retval = 0;
-#else
- *ap->a_retval = 0;
-#endif
break;
+#endif
case _PC_MIN_HOLE_SIZE:
*ap->a_retval = ap->a_vp->v_mount->mnt_stat.f_iosize;
break;
More information about the svn-src-stable-12
mailing list