NFSD: Clean up nfsd4_encode_open()
authorChuck Lever <chuck.lever@oracle.com>
Fri, 29 Sep 2023 13:59:31 +0000 (09:59 -0400)
committerChuck Lever <chuck.lever@oracle.com>
Mon, 16 Oct 2023 16:44:32 +0000 (12:44 -0400)
Finish cleaning up nfsd4_encode_open().

Reviewed-by: Jeff Layton <jlayton@kernel.org>
Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
fs/nfsd/nfs4xdr.c

index cacd069497968cbbbdb66bbc9d2872ec0ee91747..dcad27f734f60de2228a749f9e186913e10b382e 100644 (file)
@@ -4212,20 +4212,23 @@ nfsd4_encode_open(struct nfsd4_compoundres *resp, __be32 nfserr,
        struct nfsd4_open *open = &u->open;
        struct xdr_stream *xdr = resp->xdr;
 
+       /* stateid */
        nfserr = nfsd4_encode_stateid4(xdr, &open->op_stateid);
-       if (nfserr)
+       if (nfserr != nfs_ok)
                return nfserr;
+       /* cinfo */
        nfserr = nfsd4_encode_change_info4(xdr, &open->op_cinfo);
-       if (nfserr)
+       if (nfserr != nfs_ok)
                return nfserr;
-       if (xdr_stream_encode_u32(xdr, open->op_rflags) < 0)
-               return nfserr_resource;
-
+       /* rflags */
+       nfserr = nfsd4_encode_uint32_t(xdr, open->op_rflags);
+       if (nfserr != nfs_ok)
+               return nfserr;
+       /* attrset */
        nfserr = nfsd4_encode_bitmap4(xdr, open->op_bmval[0],
                                      open->op_bmval[1], open->op_bmval[2]);
-       if (nfserr)
+       if (nfserr != nfs_ok)
                return nfserr;
-
        /* delegation */
        return nfsd4_encode_open_delegation4(xdr, open);
 }