From: Chuck Lever <[email protected]>

NFSD currently provides NFSv4 clients with hard-coded responses
indicating all exported filesystems are case-sensitive and
case-preserving. This is incorrect for case-insensitive filesystems
and ext4 directories with casefold enabled.

Query the underlying filesystem's actual case sensitivity via
nfsd_get_case_info() and return accurate values to clients. This
supports per-directory settings for filesystems that allow mixing
case-sensitive and case-insensitive directories within an export.

Signed-off-by: Chuck Lever <[email protected]>
---
 fs/nfsd/nfs4xdr.c | 30 ++++++++++++++++++++++++++----
 1 file changed, 26 insertions(+), 4 deletions(-)

diff --git a/fs/nfsd/nfs4xdr.c b/fs/nfsd/nfs4xdr.c
index 51ef97c25456..167bede81273 100644
--- a/fs/nfsd/nfs4xdr.c
+++ b/fs/nfsd/nfs4xdr.c
@@ -2933,6 +2933,8 @@ struct nfsd4_fattr_args {
        u32                     rdattr_err;
        bool                    contextsupport;
        bool                    ignore_crossmnt;
+       bool                    case_insensitive;
+       bool                    case_preserving;
 };
 
 typedef __be32(*nfsd4_enc_attr)(struct xdr_stream *xdr,
@@ -3131,6 +3133,18 @@ static __be32 nfsd4_encode_fattr4_acl(struct xdr_stream 
*xdr,
        return nfs_ok;
 }
 
+static __be32 nfsd4_encode_fattr4_case_insensitive(struct xdr_stream *xdr,
+                                       const struct nfsd4_fattr_args *args)
+{
+       return nfsd4_encode_bool(xdr, args->case_insensitive);
+}
+
+static __be32 nfsd4_encode_fattr4_case_preserving(struct xdr_stream *xdr,
+                                       const struct nfsd4_fattr_args *args)
+{
+       return nfsd4_encode_bool(xdr, args->case_preserving);
+}
+
 static __be32 nfsd4_encode_fattr4_filehandle(struct xdr_stream *xdr,
                                             const struct nfsd4_fattr_args 
*args)
 {
@@ -3487,8 +3501,8 @@ static const nfsd4_enc_attr nfsd4_enc_fattr4_encode_ops[] 
= {
        [FATTR4_ACLSUPPORT]             = nfsd4_encode_fattr4_aclsupport,
        [FATTR4_ARCHIVE]                = nfsd4_encode_fattr4__noop,
        [FATTR4_CANSETTIME]             = nfsd4_encode_fattr4__true,
-       [FATTR4_CASE_INSENSITIVE]       = nfsd4_encode_fattr4__false,
-       [FATTR4_CASE_PRESERVING]        = nfsd4_encode_fattr4__true,
+       [FATTR4_CASE_INSENSITIVE]       = nfsd4_encode_fattr4_case_insensitive,
+       [FATTR4_CASE_PRESERVING]        = nfsd4_encode_fattr4_case_preserving,
        [FATTR4_CHOWN_RESTRICTED]       = nfsd4_encode_fattr4__true,
        [FATTR4_FILEHANDLE]             = nfsd4_encode_fattr4_filehandle,
        [FATTR4_FILEID]                 = nfsd4_encode_fattr4_fileid,
@@ -3674,8 +3688,9 @@ nfsd4_encode_fattr4(struct svc_rqst *rqstp, struct 
xdr_stream *xdr,
                if (err)
                        goto out_nfserr;
        }
-       if ((attrmask[0] & (FATTR4_WORD0_FILEHANDLE | FATTR4_WORD0_FSID)) &&
-           !fhp) {
+       if ((attrmask[0] & (FATTR4_WORD0_FILEHANDLE | FATTR4_WORD0_FSID |
+                           FATTR4_WORD0_CASE_INSENSITIVE |
+                           FATTR4_WORD0_CASE_PRESERVING)) && !fhp) {
                tempfh = kmalloc(sizeof(struct svc_fh), GFP_KERNEL);
                status = nfserr_jukebox;
                if (!tempfh)
@@ -3687,6 +3702,13 @@ nfsd4_encode_fattr4(struct svc_rqst *rqstp, struct 
xdr_stream *xdr,
                args.fhp = tempfh;
        } else
                args.fhp = fhp;
+       if (attrmask[0] & (FATTR4_WORD0_CASE_INSENSITIVE |
+                          FATTR4_WORD0_CASE_PRESERVING)) {
+               status = nfsd_get_case_info(args.fhp, &args.case_insensitive,
+                                           &args.case_preserving);
+               if (status != nfs_ok)
+                       goto out;
+       }
 
        if (attrmask[0] & FATTR4_WORD0_ACL) {
                err = nfsd4_get_nfs4_acl(rqstp, dentry, &args.acl);
-- 
2.52.0



_______________________________________________
Linux-f2fs-devel mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/linux-f2fs-devel

Reply via email to