Message ID | 20111219193843.30843.56764.stgit@degas.1015granger.net |
---|---|
State | Accepted |
Headers | show |
On Mon, Dec 19, 2011 at 02:38:43PM -0500, Chuck Lever wrote: > As of fedfs-utils-0.8.0, user space stores all NFS junction > information in a single extended attribute: "trusted.junction.nfs". I suspect the break of backwards-compatibility is fine, but we should add a note explaining it; would something like this be right?: This breaks compatibility with fedfs-utils versions before 0.8.0. As fedfs-utils has not been widely distributed, we don't believe this will affect anyone. (Cc'ing jlayton: does this cause a problem for whatever just went into Fedora?) --b. > > Both FedFS and NFS basic junctions are stored in this one attribute, > and the intention is that all future forms of NFS junction metadata > will be stored in this attribute. Other protocols may use a different > extended attribute. > > Thus NFSD needs to look only for that one extended attribute. The > "trusted.junction.type" xattr is deprecated. > > Signed-off-by: Chuck Lever <chuck.lever@oracle.com> > --- > > fs/nfsd/vfs.c | 17 ++++++++++++++--- > 1 files changed, 14 insertions(+), 3 deletions(-) > > diff --git a/fs/nfsd/vfs.c b/fs/nfsd/vfs.c > index d1d4d5e..b494f86 100644 > --- a/fs/nfsd/vfs.c > +++ b/fs/nfsd/vfs.c > @@ -594,8 +594,19 @@ nfsd4_get_nfs4_acl(struct svc_rqst *rqstp, struct dentry *dentry, struct nfs4_ac > return error; > } > > -#define NFSD_XATTR_JUNCTION_PREFIX XATTR_TRUSTED_PREFIX "junction." > -#define NFSD_XATTR_JUNCTION_TYPE NFSD_XATTR_JUNCTION_PREFIX "type" > +/* > + * NFS junction information is stored in an extended attribute. > + */ > +#define NFSD_JUNCTION_XATTR_NAME XATTR_TRUSTED_PREFIX "junction.nfs" > + > +/** > + * nfsd4_is_junction - Test if an object could be an NFS junction > + * > + * @dentry: object to test > + * > + * Returns 1 if "dentry" appears to contain NFS junction information. > + * Otherwise 0 is returned. > + */ > int nfsd4_is_junction(struct dentry *dentry) > { > struct inode *inode = dentry->d_inode; > @@ -606,7 +617,7 @@ int nfsd4_is_junction(struct dentry *dentry) > return 0; > if (!(inode->i_mode & S_ISVTX)) > return 0; > - if (vfs_getxattr(dentry, NFSD_XATTR_JUNCTION_TYPE, NULL, 0) <= 0) > + if (vfs_getxattr(dentry, NFSD_JUNCTION_XATTR_NAME, NULL, 0) <= 0) > return 0; > return 1; > } >
On Dec 19, 2011, at 4:52 PM, J. Bruce Fields wrote: > On Mon, Dec 19, 2011 at 02:38:43PM -0500, Chuck Lever wrote: >> As of fedfs-utils-0.8.0, user space stores all NFS junction >> information in a single extended attribute: "trusted.junction.nfs". > > I suspect the break of backwards-compatibility is fine, but we should > add a note explaining it; would something like this be right?: > > This breaks compatibility with fedfs-utils versions before > 0.8.0. As fedfs-utils has not been widely distributed, we don't > believe this will affect anyone. More strongly: fedfs-utils is an alpha quality code release. We don't guarantee any backwards compatibility. > (Cc'ing jlayton: does this cause a problem for whatever just went into > Fedora?) > > --b. > >> >> Both FedFS and NFS basic junctions are stored in this one attribute, >> and the intention is that all future forms of NFS junction metadata >> will be stored in this attribute. Other protocols may use a different >> extended attribute. >> >> Thus NFSD needs to look only for that one extended attribute. The >> "trusted.junction.type" xattr is deprecated. >> >> Signed-off-by: Chuck Lever <chuck.lever@oracle.com> >> --- >> >> fs/nfsd/vfs.c | 17 ++++++++++++++--- >> 1 files changed, 14 insertions(+), 3 deletions(-) >> >> diff --git a/fs/nfsd/vfs.c b/fs/nfsd/vfs.c >> index d1d4d5e..b494f86 100644 >> --- a/fs/nfsd/vfs.c >> +++ b/fs/nfsd/vfs.c >> @@ -594,8 +594,19 @@ nfsd4_get_nfs4_acl(struct svc_rqst *rqstp, struct dentry *dentry, struct nfs4_ac >> return error; >> } >> >> -#define NFSD_XATTR_JUNCTION_PREFIX XATTR_TRUSTED_PREFIX "junction." >> -#define NFSD_XATTR_JUNCTION_TYPE NFSD_XATTR_JUNCTION_PREFIX "type" >> +/* >> + * NFS junction information is stored in an extended attribute. >> + */ >> +#define NFSD_JUNCTION_XATTR_NAME XATTR_TRUSTED_PREFIX "junction.nfs" >> + >> +/** >> + * nfsd4_is_junction - Test if an object could be an NFS junction >> + * >> + * @dentry: object to test >> + * >> + * Returns 1 if "dentry" appears to contain NFS junction information. >> + * Otherwise 0 is returned. >> + */ >> int nfsd4_is_junction(struct dentry *dentry) >> { >> struct inode *inode = dentry->d_inode; >> @@ -606,7 +617,7 @@ int nfsd4_is_junction(struct dentry *dentry) >> return 0; >> if (!(inode->i_mode & S_ISVTX)) >> return 0; >> - if (vfs_getxattr(dentry, NFSD_XATTR_JUNCTION_TYPE, NULL, 0) <= 0) >> + if (vfs_getxattr(dentry, NFSD_JUNCTION_XATTR_NAME, NULL, 0) <= 0) >> return 0; >> return 1; >> } >> > -- > To unsubscribe from this list: send the line "unsubscribe linux-nfs" in > the body of a message to majordomo@vger.kernel.org > More majordomo info at http://vger.kernel.org/majordomo-info.html
On Mon, 19 Dec 2011 16:52:59 -0500 "J. Bruce Fields" <bfields@fieldses.org> wrote: > On Mon, Dec 19, 2011 at 02:38:43PM -0500, Chuck Lever wrote: > > As of fedfs-utils-0.8.0, user space stores all NFS junction > > information in a single extended attribute: "trusted.junction.nfs". > > I suspect the break of backwards-compatibility is fine, but we should > add a note explaining it; would something like this be right?: > > This breaks compatibility with fedfs-utils versions before > 0.8.0. As fedfs-utils has not been widely distributed, we don't > believe this will affect anyone. > > (Cc'ing jlayton: does this cause a problem for whatever just went into > Fedora?) > Also cc'ing Ian, on whose shoulders I dumped the fedfs work... That stuff just went into Fedora rawhide, and as everyone knows (or should) -- rawhide eats babies. At this point I don't think there's any need to worry about compatibility issues.
On Mon, Dec 19, 2011 at 05:19:57PM -0500, Jeff Layton wrote: > On Mon, 19 Dec 2011 16:52:59 -0500 > "J. Bruce Fields" <bfields@fieldses.org> wrote: > > > On Mon, Dec 19, 2011 at 02:38:43PM -0500, Chuck Lever wrote: > > > As of fedfs-utils-0.8.0, user space stores all NFS junction > > > information in a single extended attribute: "trusted.junction.nfs". > > > > I suspect the break of backwards-compatibility is fine, but we should > > add a note explaining it; would something like this be right?: > > > > This breaks compatibility with fedfs-utils versions before > > 0.8.0. As fedfs-utils has not been widely distributed, we don't > > believe this will affect anyone. > > > > (Cc'ing jlayton: does this cause a problem for whatever just went into > > Fedora?) > > > > Also cc'ing Ian, on whose shoulders I dumped the fedfs work... > > That stuff just went into Fedora rawhide, and as everyone knows (or > should) -- rawhide eats babies. At this point I don't think there's any > need to worry about compatibility issues. OK, thanks. (Chuck, that's the more important question to me than whether we declare done or not: if it's alpha-quality code but somebody nevertheless manages to get a working setup out of it, we try to be nice to them and not break that. If it's only been distributed in rawhide, and only a little while, chances of that are very small, so fine.) --b.
On Mon, 2011-12-19 at 17:26 -0500, J. Bruce Fields wrote: > On Mon, Dec 19, 2011 at 05:19:57PM -0500, Jeff Layton wrote: > > On Mon, 19 Dec 2011 16:52:59 -0500 > > "J. Bruce Fields" <bfields@fieldses.org> wrote: > > > > > On Mon, Dec 19, 2011 at 02:38:43PM -0500, Chuck Lever wrote: > > > > As of fedfs-utils-0.8.0, user space stores all NFS junction > > > > information in a single extended attribute: "trusted.junction.nfs". > > > > > > I suspect the break of backwards-compatibility is fine, but we should > > > add a note explaining it; would something like this be right?: > > > > > > This breaks compatibility with fedfs-utils versions before > > > 0.8.0. As fedfs-utils has not been widely distributed, we don't > > > believe this will affect anyone. > > > > > > (Cc'ing jlayton: does this cause a problem for whatever just went into > > > Fedora?) > > > > > > > Also cc'ing Ian, on whose shoulders I dumped the fedfs work... > > > > That stuff just went into Fedora rawhide, and as everyone knows (or > > should) -- rawhide eats babies. At this point I don't think there's any > > need to worry about compatibility issues. > > OK, thanks. > > (Chuck, that's the more important question to me than whether we declare > done or not: if it's alpha-quality code but somebody nevertheless > manages to get a working setup out of it, we try to be nice to them and > not break that. If it's only been distributed in rawhide, and only a > little while, chances of that are very small, so fine.) Yeah, alpha stage development shouldn't be constrained by backward compatibly concerns. Of course a heads up to users is good too. Ian
diff --git a/fs/nfsd/vfs.c b/fs/nfsd/vfs.c index d1d4d5e..b494f86 100644 --- a/fs/nfsd/vfs.c +++ b/fs/nfsd/vfs.c @@ -594,8 +594,19 @@ nfsd4_get_nfs4_acl(struct svc_rqst *rqstp, struct dentry *dentry, struct nfs4_ac return error; } -#define NFSD_XATTR_JUNCTION_PREFIX XATTR_TRUSTED_PREFIX "junction." -#define NFSD_XATTR_JUNCTION_TYPE NFSD_XATTR_JUNCTION_PREFIX "type" +/* + * NFS junction information is stored in an extended attribute. + */ +#define NFSD_JUNCTION_XATTR_NAME XATTR_TRUSTED_PREFIX "junction.nfs" + +/** + * nfsd4_is_junction - Test if an object could be an NFS junction + * + * @dentry: object to test + * + * Returns 1 if "dentry" appears to contain NFS junction information. + * Otherwise 0 is returned. + */ int nfsd4_is_junction(struct dentry *dentry) { struct inode *inode = dentry->d_inode; @@ -606,7 +617,7 @@ int nfsd4_is_junction(struct dentry *dentry) return 0; if (!(inode->i_mode & S_ISVTX)) return 0; - if (vfs_getxattr(dentry, NFSD_XATTR_JUNCTION_TYPE, NULL, 0) <= 0) + if (vfs_getxattr(dentry, NFSD_JUNCTION_XATTR_NAME, NULL, 0) <= 0) return 0; return 1; }
As of fedfs-utils-0.8.0, user space stores all NFS junction information in a single extended attribute: "trusted.junction.nfs". Both FedFS and NFS basic junctions are stored in this one attribute, and the intention is that all future forms of NFS junction metadata will be stored in this attribute. Other protocols may use a different extended attribute. Thus NFSD needs to look only for that one extended attribute. The "trusted.junction.type" xattr is deprecated. Signed-off-by: Chuck Lever <chuck.lever@oracle.com> --- fs/nfsd/vfs.c | 17 ++++++++++++++--- 1 files changed, 14 insertions(+), 3 deletions(-)