nfsd: clean up an xdr reserved space calculation
authorKinglong Mee <kinglongmee@gmail.com>
Mon, 9 Dec 2013 11:31:21 +0000 (19:31 +0800)
committerJ. Bruce Fields <bfields@redhat.com>
Fri, 3 Jan 2014 18:44:12 +0000 (13:44 -0500)
We should use XDR_LEN to calculate reserved space in case the oid is not
a multiple of 4.

RESERVE_SPACE actually rounds up for us, but it's probably better to be
careful here.

Signed-off-by: Kinglong Mee <kinglongmee@gmail.com>
Signed-off-by: J. Bruce Fields <bfields@redhat.com>
fs/nfsd/nfs4xdr.c

index 1dface03bd3e5b1ae22d4be3b9ba8bf2e9a6a94c..dbd64a9d268b0cd82cbf0caba5780b1480336299 100644 (file)
@@ -3263,7 +3263,7 @@ nfsd4_do_encode_secinfo(struct nfsd4_compoundres *resp,
 
                if (rpcauth_get_gssinfo(pf, &info) == 0) {
                        supported++;
-                       RESERVE_SPACE(4 + 4 + info.oid.len + 4 + 4);
+                       RESERVE_SPACE(4 + 4 + XDR_LEN(info.oid.len) + 4 + 4);
                        WRITE32(RPC_AUTH_GSS);
                        WRITE32(info.oid.len);
                        WRITEMEM(info.oid.data, info.oid.len);