diff options
-rw-r--r-- | fs/nfs/nfs4xdr.c | 42 |
1 files changed, 14 insertions, 28 deletions
diff --git a/fs/nfs/nfs4xdr.c b/fs/nfs/nfs4xdr.c index d75f821cad01..efa78ad98228 100644 --- a/fs/nfs/nfs4xdr.c +++ b/fs/nfs/nfs4xdr.c | |||
@@ -732,9 +732,8 @@ static void encode_compound_hdr(struct xdr_stream *xdr, | |||
732 | 732 | ||
733 | dprintk("encode_compound: tag=%.*s\n", (int)hdr->taglen, hdr->tag); | 733 | dprintk("encode_compound: tag=%.*s\n", (int)hdr->taglen, hdr->tag); |
734 | BUG_ON(hdr->taglen > NFS4_MAXTAGLEN); | 734 | BUG_ON(hdr->taglen > NFS4_MAXTAGLEN); |
735 | p = reserve_space(xdr, 12 + hdr->taglen); | 735 | p = reserve_space(xdr, 4 + hdr->taglen + 8); |
736 | *p++ = cpu_to_be32(hdr->taglen); | 736 | p = xdr_encode_opaque(p, hdr->tag, hdr->taglen); |
737 | p = xdr_encode_opaque_fixed(p, hdr->tag, hdr->taglen); | ||
738 | *p++ = cpu_to_be32(hdr->minorversion); | 737 | *p++ = cpu_to_be32(hdr->minorversion); |
739 | hdr->nops_p = p; | 738 | hdr->nops_p = p; |
740 | *p = cpu_to_be32(hdr->nops); | 739 | *p = cpu_to_be32(hdr->nops); |
@@ -832,13 +831,11 @@ static void encode_attrs(struct xdr_stream *xdr, const struct iattr *iap, const | |||
832 | } | 831 | } |
833 | if (iap->ia_valid & ATTR_UID) { | 832 | if (iap->ia_valid & ATTR_UID) { |
834 | bmval1 |= FATTR4_WORD1_OWNER; | 833 | bmval1 |= FATTR4_WORD1_OWNER; |
835 | *p++ = cpu_to_be32(owner_namelen); | 834 | p = xdr_encode_opaque(p, owner_name, owner_namelen); |
836 | p = xdr_encode_opaque_fixed(p, owner_name, owner_namelen); | ||
837 | } | 835 | } |
838 | if (iap->ia_valid & ATTR_GID) { | 836 | if (iap->ia_valid & ATTR_GID) { |
839 | bmval1 |= FATTR4_WORD1_OWNER_GROUP; | 837 | bmval1 |= FATTR4_WORD1_OWNER_GROUP; |
840 | *p++ = cpu_to_be32(owner_grouplen); | 838 | p = xdr_encode_opaque(p, owner_group, owner_grouplen); |
841 | p = xdr_encode_opaque_fixed(p, owner_group, owner_grouplen); | ||
842 | } | 839 | } |
843 | if (iap->ia_valid & ATTR_ATIME_SET) { | 840 | if (iap->ia_valid & ATTR_ATIME_SET) { |
844 | bmval1 |= FATTR4_WORD1_TIME_ACCESS_SET; | 841 | bmval1 |= FATTR4_WORD1_TIME_ACCESS_SET; |
@@ -939,9 +936,7 @@ static void encode_create(struct xdr_stream *xdr, const struct nfs4_create_arg * | |||
939 | break; | 936 | break; |
940 | } | 937 | } |
941 | 938 | ||
942 | p = reserve_space(xdr, 4 + create->name->len); | 939 | encode_string(xdr, create->name->len, create->name->name); |
943 | *p++ = cpu_to_be32(create->name->len); | ||
944 | xdr_encode_opaque_fixed(p, create->name->name, create->name->len); | ||
945 | hdr->nops++; | 940 | hdr->nops++; |
946 | hdr->replen += decode_create_maxsz; | 941 | hdr->replen += decode_create_maxsz; |
947 | 942 | ||
@@ -1007,8 +1002,7 @@ static void encode_link(struct xdr_stream *xdr, const struct qstr *name, struct | |||
1007 | 1002 | ||
1008 | p = reserve_space(xdr, 8 + name->len); | 1003 | p = reserve_space(xdr, 8 + name->len); |
1009 | *p++ = cpu_to_be32(OP_LINK); | 1004 | *p++ = cpu_to_be32(OP_LINK); |
1010 | *p++ = cpu_to_be32(name->len); | 1005 | xdr_encode_opaque(p, name->name, name->len); |
1011 | xdr_encode_opaque_fixed(p, name->name, name->len); | ||
1012 | hdr->nops++; | 1006 | hdr->nops++; |
1013 | hdr->replen += decode_link_maxsz; | 1007 | hdr->replen += decode_link_maxsz; |
1014 | } | 1008 | } |
@@ -1100,8 +1094,7 @@ static void encode_lookup(struct xdr_stream *xdr, const struct qstr *name, struc | |||
1100 | 1094 | ||
1101 | p = reserve_space(xdr, 8 + len); | 1095 | p = reserve_space(xdr, 8 + len); |
1102 | *p++ = cpu_to_be32(OP_LOOKUP); | 1096 | *p++ = cpu_to_be32(OP_LOOKUP); |
1103 | *p++ = cpu_to_be32(len); | 1097 | xdr_encode_opaque(p, name->name, len); |
1104 | xdr_encode_opaque_fixed(p, name->name, len); | ||
1105 | hdr->nops++; | 1098 | hdr->nops++; |
1106 | hdr->replen += decode_lookup_maxsz; | 1099 | hdr->replen += decode_lookup_maxsz; |
1107 | } | 1100 | } |
@@ -1279,8 +1272,7 @@ encode_putfh(struct xdr_stream *xdr, const struct nfs_fh *fh, struct compound_hd | |||
1279 | 1272 | ||
1280 | p = reserve_space(xdr, 8 + len); | 1273 | p = reserve_space(xdr, 8 + len); |
1281 | *p++ = cpu_to_be32(OP_PUTFH); | 1274 | *p++ = cpu_to_be32(OP_PUTFH); |
1282 | *p++ = cpu_to_be32(len); | 1275 | xdr_encode_opaque(p, fh->data, len); |
1283 | xdr_encode_opaque_fixed(p, fh->data, len); | ||
1284 | hdr->nops++; | 1276 | hdr->nops++; |
1285 | hdr->replen += decode_putfh_maxsz; | 1277 | hdr->replen += decode_putfh_maxsz; |
1286 | } | 1278 | } |
@@ -1373,8 +1365,7 @@ static void encode_remove(struct xdr_stream *xdr, const struct qstr *name, struc | |||
1373 | 1365 | ||
1374 | p = reserve_space(xdr, 8 + name->len); | 1366 | p = reserve_space(xdr, 8 + name->len); |
1375 | *p++ = cpu_to_be32(OP_REMOVE); | 1367 | *p++ = cpu_to_be32(OP_REMOVE); |
1376 | *p++ = cpu_to_be32(name->len); | 1368 | xdr_encode_opaque(p, name->name, name->len); |
1377 | xdr_encode_opaque_fixed(p, name->name, name->len); | ||
1378 | hdr->nops++; | 1369 | hdr->nops++; |
1379 | hdr->replen += decode_remove_maxsz; | 1370 | hdr->replen += decode_remove_maxsz; |
1380 | } | 1371 | } |
@@ -1383,14 +1374,10 @@ static void encode_rename(struct xdr_stream *xdr, const struct qstr *oldname, co | |||
1383 | { | 1374 | { |
1384 | __be32 *p; | 1375 | __be32 *p; |
1385 | 1376 | ||
1386 | p = reserve_space(xdr, 8 + oldname->len); | 1377 | p = reserve_space(xdr, 4); |
1387 | *p++ = cpu_to_be32(OP_RENAME); | 1378 | *p = cpu_to_be32(OP_RENAME); |
1388 | *p++ = cpu_to_be32(oldname->len); | 1379 | encode_string(xdr, oldname->len, oldname->name); |
1389 | xdr_encode_opaque_fixed(p, oldname->name, oldname->len); | 1380 | encode_string(xdr, newname->len, newname->name); |
1390 | |||
1391 | p = reserve_space(xdr, 4 + newname->len); | ||
1392 | *p++ = cpu_to_be32(newname->len); | ||
1393 | xdr_encode_opaque_fixed(p, newname->name, newname->len); | ||
1394 | hdr->nops++; | 1381 | hdr->nops++; |
1395 | hdr->replen += decode_rename_maxsz; | 1382 | hdr->replen += decode_rename_maxsz; |
1396 | } | 1383 | } |
@@ -1587,8 +1574,7 @@ static void encode_create_session(struct xdr_stream *xdr, | |||
1587 | 1574 | ||
1588 | /* authsys_parms rfc1831 */ | 1575 | /* authsys_parms rfc1831 */ |
1589 | *p++ = cpu_to_be32((u32)clp->cl_boot_time.tv_nsec); /* stamp */ | 1576 | *p++ = cpu_to_be32((u32)clp->cl_boot_time.tv_nsec); /* stamp */ |
1590 | *p++ = cpu_to_be32(len); | 1577 | p = xdr_encode_opaque(p, machine_name, len); |
1591 | p = xdr_encode_opaque_fixed(p, machine_name, len); | ||
1592 | *p++ = cpu_to_be32(0); /* UID */ | 1578 | *p++ = cpu_to_be32(0); /* UID */ |
1593 | *p++ = cpu_to_be32(0); /* GID */ | 1579 | *p++ = cpu_to_be32(0); /* GID */ |
1594 | *p = cpu_to_be32(0); /* No more gids */ | 1580 | *p = cpu_to_be32(0); /* No more gids */ |