diff options
Diffstat (limited to 'fs/nfs/nfs4xdr.c')
-rw-r--r-- | fs/nfs/nfs4xdr.c | 145 |
1 files changed, 72 insertions, 73 deletions
diff --git a/fs/nfs/nfs4xdr.c b/fs/nfs/nfs4xdr.c index efa78ad98228..5f6b46f17c5b 100644 --- a/fs/nfs/nfs4xdr.c +++ b/fs/nfs/nfs4xdr.c | |||
@@ -2433,7 +2433,6 @@ static int nfs4_xdr_enc_get_lease_time(struct rpc_rqst *req, uint32_t *p, | |||
2433 | * task to translate them into Linux-specific versions which are more | 2433 | * task to translate them into Linux-specific versions which are more |
2434 | * consistent with the style used in NFSv2/v3... | 2434 | * consistent with the style used in NFSv2/v3... |
2435 | */ | 2435 | */ |
2436 | #define READ32(x) (x) = ntohl(*p++) | ||
2437 | #define READ64(x) do { \ | 2436 | #define READ64(x) do { \ |
2438 | (x) = (u64)ntohl(*p++) << 32; \ | 2437 | (x) = (u64)ntohl(*p++) << 32; \ |
2439 | (x) |= ntohl(*p++); \ | 2438 | (x) |= ntohl(*p++); \ |
@@ -2464,7 +2463,7 @@ static int decode_opaque_inline(struct xdr_stream *xdr, unsigned int *len, char | |||
2464 | __be32 *p; | 2463 | __be32 *p; |
2465 | 2464 | ||
2466 | READ_BUF(4); | 2465 | READ_BUF(4); |
2467 | READ32(*len); | 2466 | *len = be32_to_cpup(p++); |
2468 | READ_BUF(*len); | 2467 | READ_BUF(*len); |
2469 | *string = (char *)p; | 2468 | *string = (char *)p; |
2470 | return 0; | 2469 | return 0; |
@@ -2475,13 +2474,13 @@ static int decode_compound_hdr(struct xdr_stream *xdr, struct compound_hdr *hdr) | |||
2475 | __be32 *p; | 2474 | __be32 *p; |
2476 | 2475 | ||
2477 | READ_BUF(8); | 2476 | READ_BUF(8); |
2478 | READ32(hdr->status); | 2477 | hdr->status = be32_to_cpup(p++); |
2479 | READ32(hdr->taglen); | 2478 | hdr->taglen = be32_to_cpup(p++); |
2480 | 2479 | ||
2481 | READ_BUF(hdr->taglen + 4); | 2480 | READ_BUF(hdr->taglen + 4); |
2482 | hdr->tag = (char *)p; | 2481 | hdr->tag = (char *)p; |
2483 | p += XDR_QUADLEN(hdr->taglen); | 2482 | p += XDR_QUADLEN(hdr->taglen); |
2484 | READ32(hdr->nops); | 2483 | hdr->nops = be32_to_cpup(p++); |
2485 | if (unlikely(hdr->nops < 1)) | 2484 | if (unlikely(hdr->nops < 1)) |
2486 | return nfs4_stat_to_errno(hdr->status); | 2485 | return nfs4_stat_to_errno(hdr->status); |
2487 | return 0; | 2486 | return 0; |
@@ -2494,14 +2493,14 @@ static int decode_op_hdr(struct xdr_stream *xdr, enum nfs_opnum4 expected) | |||
2494 | int32_t nfserr; | 2493 | int32_t nfserr; |
2495 | 2494 | ||
2496 | READ_BUF(8); | 2495 | READ_BUF(8); |
2497 | READ32(opnum); | 2496 | opnum = be32_to_cpup(p++); |
2498 | if (opnum != expected) { | 2497 | if (opnum != expected) { |
2499 | dprintk("nfs: Server returned operation" | 2498 | dprintk("nfs: Server returned operation" |
2500 | " %d but we issued a request for %d\n", | 2499 | " %d but we issued a request for %d\n", |
2501 | opnum, expected); | 2500 | opnum, expected); |
2502 | return -EIO; | 2501 | return -EIO; |
2503 | } | 2502 | } |
2504 | READ32(nfserr); | 2503 | nfserr = be32_to_cpup(p++); |
2505 | if (nfserr != NFS_OK) | 2504 | if (nfserr != NFS_OK) |
2506 | return nfs4_stat_to_errno(nfserr); | 2505 | return nfs4_stat_to_errno(nfserr); |
2507 | return 0; | 2506 | return 0; |
@@ -2524,14 +2523,14 @@ static int decode_attr_bitmap(struct xdr_stream *xdr, uint32_t *bitmap) | |||
2524 | __be32 *p; | 2523 | __be32 *p; |
2525 | 2524 | ||
2526 | READ_BUF(4); | 2525 | READ_BUF(4); |
2527 | READ32(bmlen); | 2526 | bmlen = be32_to_cpup(p++); |
2528 | 2527 | ||
2529 | bitmap[0] = bitmap[1] = 0; | 2528 | bitmap[0] = bitmap[1] = 0; |
2530 | READ_BUF((bmlen << 2)); | 2529 | READ_BUF((bmlen << 2)); |
2531 | if (bmlen > 0) { | 2530 | if (bmlen > 0) { |
2532 | READ32(bitmap[0]); | 2531 | bitmap[0] = be32_to_cpup(p++); |
2533 | if (bmlen > 1) | 2532 | if (bmlen > 1) |
2534 | READ32(bitmap[1]); | 2533 | bitmap[1] = be32_to_cpup(p++); |
2535 | } | 2534 | } |
2536 | return 0; | 2535 | return 0; |
2537 | } | 2536 | } |
@@ -2541,7 +2540,7 @@ static inline int decode_attr_length(struct xdr_stream *xdr, uint32_t *attrlen, | |||
2541 | __be32 *p; | 2540 | __be32 *p; |
2542 | 2541 | ||
2543 | READ_BUF(4); | 2542 | READ_BUF(4); |
2544 | READ32(*attrlen); | 2543 | *attrlen = be32_to_cpup(p++); |
2545 | *savep = xdr->p; | 2544 | *savep = xdr->p; |
2546 | return 0; | 2545 | return 0; |
2547 | } | 2546 | } |
@@ -2567,7 +2566,7 @@ static int decode_attr_type(struct xdr_stream *xdr, uint32_t *bitmap, uint32_t * | |||
2567 | return -EIO; | 2566 | return -EIO; |
2568 | if (likely(bitmap[0] & FATTR4_WORD0_TYPE)) { | 2567 | if (likely(bitmap[0] & FATTR4_WORD0_TYPE)) { |
2569 | READ_BUF(4); | 2568 | READ_BUF(4); |
2570 | READ32(*type); | 2569 | *type = be32_to_cpup(p++); |
2571 | if (*type < NF4REG || *type > NF4NAMEDATTR) { | 2570 | if (*type < NF4REG || *type > NF4NAMEDATTR) { |
2572 | dprintk("%s: bad type %d\n", __func__, *type); | 2571 | dprintk("%s: bad type %d\n", __func__, *type); |
2573 | return -EIO; | 2572 | return -EIO; |
@@ -2625,7 +2624,7 @@ static int decode_attr_link_support(struct xdr_stream *xdr, uint32_t *bitmap, ui | |||
2625 | return -EIO; | 2624 | return -EIO; |
2626 | if (likely(bitmap[0] & FATTR4_WORD0_LINK_SUPPORT)) { | 2625 | if (likely(bitmap[0] & FATTR4_WORD0_LINK_SUPPORT)) { |
2627 | READ_BUF(4); | 2626 | READ_BUF(4); |
2628 | READ32(*res); | 2627 | *res = be32_to_cpup(p++); |
2629 | bitmap[0] &= ~FATTR4_WORD0_LINK_SUPPORT; | 2628 | bitmap[0] &= ~FATTR4_WORD0_LINK_SUPPORT; |
2630 | } | 2629 | } |
2631 | dprintk("%s: link support=%s\n", __func__, *res == 0 ? "false" : "true"); | 2630 | dprintk("%s: link support=%s\n", __func__, *res == 0 ? "false" : "true"); |
@@ -2641,7 +2640,7 @@ static int decode_attr_symlink_support(struct xdr_stream *xdr, uint32_t *bitmap, | |||
2641 | return -EIO; | 2640 | return -EIO; |
2642 | if (likely(bitmap[0] & FATTR4_WORD0_SYMLINK_SUPPORT)) { | 2641 | if (likely(bitmap[0] & FATTR4_WORD0_SYMLINK_SUPPORT)) { |
2643 | READ_BUF(4); | 2642 | READ_BUF(4); |
2644 | READ32(*res); | 2643 | *res = be32_to_cpup(p++); |
2645 | bitmap[0] &= ~FATTR4_WORD0_SYMLINK_SUPPORT; | 2644 | bitmap[0] &= ~FATTR4_WORD0_SYMLINK_SUPPORT; |
2646 | } | 2645 | } |
2647 | dprintk("%s: symlink support=%s\n", __func__, *res == 0 ? "false" : "true"); | 2646 | dprintk("%s: symlink support=%s\n", __func__, *res == 0 ? "false" : "true"); |
@@ -2679,7 +2678,7 @@ static int decode_attr_lease_time(struct xdr_stream *xdr, uint32_t *bitmap, uint | |||
2679 | return -EIO; | 2678 | return -EIO; |
2680 | if (likely(bitmap[0] & FATTR4_WORD0_LEASE_TIME)) { | 2679 | if (likely(bitmap[0] & FATTR4_WORD0_LEASE_TIME)) { |
2681 | READ_BUF(4); | 2680 | READ_BUF(4); |
2682 | READ32(*res); | 2681 | *res = be32_to_cpup(p++); |
2683 | bitmap[0] &= ~FATTR4_WORD0_LEASE_TIME; | 2682 | bitmap[0] &= ~FATTR4_WORD0_LEASE_TIME; |
2684 | } | 2683 | } |
2685 | dprintk("%s: file size=%u\n", __func__, (unsigned int)*res); | 2684 | dprintk("%s: file size=%u\n", __func__, (unsigned int)*res); |
@@ -2695,7 +2694,7 @@ static int decode_attr_aclsupport(struct xdr_stream *xdr, uint32_t *bitmap, uint | |||
2695 | return -EIO; | 2694 | return -EIO; |
2696 | if (likely(bitmap[0] & FATTR4_WORD0_ACLSUPPORT)) { | 2695 | if (likely(bitmap[0] & FATTR4_WORD0_ACLSUPPORT)) { |
2697 | READ_BUF(4); | 2696 | READ_BUF(4); |
2698 | READ32(*res); | 2697 | *res = be32_to_cpup(p++); |
2699 | bitmap[0] &= ~FATTR4_WORD0_ACLSUPPORT; | 2698 | bitmap[0] &= ~FATTR4_WORD0_ACLSUPPORT; |
2700 | } | 2699 | } |
2701 | dprintk("%s: ACLs supported=%u\n", __func__, (unsigned int)*res); | 2700 | dprintk("%s: ACLs supported=%u\n", __func__, (unsigned int)*res); |
@@ -2796,7 +2795,7 @@ static int decode_pathname(struct xdr_stream *xdr, struct nfs4_pathname *path) | |||
2796 | int status = 0; | 2795 | int status = 0; |
2797 | 2796 | ||
2798 | READ_BUF(4); | 2797 | READ_BUF(4); |
2799 | READ32(n); | 2798 | n = be32_to_cpup(p++); |
2800 | if (n == 0) | 2799 | if (n == 0) |
2801 | goto root_path; | 2800 | goto root_path; |
2802 | dprintk("path "); | 2801 | dprintk("path "); |
@@ -2848,7 +2847,7 @@ static int decode_attr_fs_locations(struct xdr_stream *xdr, uint32_t *bitmap, st | |||
2848 | if (unlikely(status != 0)) | 2847 | if (unlikely(status != 0)) |
2849 | goto out; | 2848 | goto out; |
2850 | READ_BUF(4); | 2849 | READ_BUF(4); |
2851 | READ32(n); | 2850 | n = be32_to_cpup(p++); |
2852 | if (n <= 0) | 2851 | if (n <= 0) |
2853 | goto out_eio; | 2852 | goto out_eio; |
2854 | res->nlocations = 0; | 2853 | res->nlocations = 0; |
@@ -2857,7 +2856,7 @@ static int decode_attr_fs_locations(struct xdr_stream *xdr, uint32_t *bitmap, st | |||
2857 | struct nfs4_fs_location *loc = &res->locations[res->nlocations]; | 2856 | struct nfs4_fs_location *loc = &res->locations[res->nlocations]; |
2858 | 2857 | ||
2859 | READ_BUF(4); | 2858 | READ_BUF(4); |
2860 | READ32(m); | 2859 | m = be32_to_cpup(p++); |
2861 | 2860 | ||
2862 | loc->nservers = 0; | 2861 | loc->nservers = 0; |
2863 | dprintk("%s: servers ", __func__); | 2862 | dprintk("%s: servers ", __func__); |
@@ -2928,7 +2927,7 @@ static int decode_attr_maxlink(struct xdr_stream *xdr, uint32_t *bitmap, uint32_ | |||
2928 | return -EIO; | 2927 | return -EIO; |
2929 | if (likely(bitmap[0] & FATTR4_WORD0_MAXLINK)) { | 2928 | if (likely(bitmap[0] & FATTR4_WORD0_MAXLINK)) { |
2930 | READ_BUF(4); | 2929 | READ_BUF(4); |
2931 | READ32(*maxlink); | 2930 | *maxlink = be32_to_cpup(p++); |
2932 | bitmap[0] &= ~FATTR4_WORD0_MAXLINK; | 2931 | bitmap[0] &= ~FATTR4_WORD0_MAXLINK; |
2933 | } | 2932 | } |
2934 | dprintk("%s: maxlink=%u\n", __func__, *maxlink); | 2933 | dprintk("%s: maxlink=%u\n", __func__, *maxlink); |
@@ -2945,7 +2944,7 @@ static int decode_attr_maxname(struct xdr_stream *xdr, uint32_t *bitmap, uint32_ | |||
2945 | return -EIO; | 2944 | return -EIO; |
2946 | if (likely(bitmap[0] & FATTR4_WORD0_MAXNAME)) { | 2945 | if (likely(bitmap[0] & FATTR4_WORD0_MAXNAME)) { |
2947 | READ_BUF(4); | 2946 | READ_BUF(4); |
2948 | READ32(*maxname); | 2947 | *maxname = be32_to_cpup(p++); |
2949 | bitmap[0] &= ~FATTR4_WORD0_MAXNAME; | 2948 | bitmap[0] &= ~FATTR4_WORD0_MAXNAME; |
2950 | } | 2949 | } |
2951 | dprintk("%s: maxname=%u\n", __func__, *maxname); | 2950 | dprintk("%s: maxname=%u\n", __func__, *maxname); |
@@ -3005,7 +3004,7 @@ static int decode_attr_mode(struct xdr_stream *xdr, uint32_t *bitmap, umode_t *m | |||
3005 | return -EIO; | 3004 | return -EIO; |
3006 | if (likely(bitmap[1] & FATTR4_WORD1_MODE)) { | 3005 | if (likely(bitmap[1] & FATTR4_WORD1_MODE)) { |
3007 | READ_BUF(4); | 3006 | READ_BUF(4); |
3008 | READ32(tmp); | 3007 | tmp = be32_to_cpup(p++); |
3009 | *mode = tmp & ~S_IFMT; | 3008 | *mode = tmp & ~S_IFMT; |
3010 | bitmap[1] &= ~FATTR4_WORD1_MODE; | 3009 | bitmap[1] &= ~FATTR4_WORD1_MODE; |
3011 | ret = NFS_ATTR_FATTR_MODE; | 3010 | ret = NFS_ATTR_FATTR_MODE; |
@@ -3024,7 +3023,7 @@ static int decode_attr_nlink(struct xdr_stream *xdr, uint32_t *bitmap, uint32_t | |||
3024 | return -EIO; | 3023 | return -EIO; |
3025 | if (likely(bitmap[1] & FATTR4_WORD1_NUMLINKS)) { | 3024 | if (likely(bitmap[1] & FATTR4_WORD1_NUMLINKS)) { |
3026 | READ_BUF(4); | 3025 | READ_BUF(4); |
3027 | READ32(*nlink); | 3026 | *nlink = be32_to_cpup(p++); |
3028 | bitmap[1] &= ~FATTR4_WORD1_NUMLINKS; | 3027 | bitmap[1] &= ~FATTR4_WORD1_NUMLINKS; |
3029 | ret = NFS_ATTR_FATTR_NLINK; | 3028 | ret = NFS_ATTR_FATTR_NLINK; |
3030 | } | 3029 | } |
@@ -3043,7 +3042,7 @@ static int decode_attr_owner(struct xdr_stream *xdr, uint32_t *bitmap, struct nf | |||
3043 | return -EIO; | 3042 | return -EIO; |
3044 | if (likely(bitmap[1] & FATTR4_WORD1_OWNER)) { | 3043 | if (likely(bitmap[1] & FATTR4_WORD1_OWNER)) { |
3045 | READ_BUF(4); | 3044 | READ_BUF(4); |
3046 | READ32(len); | 3045 | len = be32_to_cpup(p++); |
3047 | READ_BUF(len); | 3046 | READ_BUF(len); |
3048 | if (len < XDR_MAX_NETOBJ) { | 3047 | if (len < XDR_MAX_NETOBJ) { |
3049 | if (nfs_map_name_to_uid(clp, (char *)p, len, uid) == 0) | 3048 | if (nfs_map_name_to_uid(clp, (char *)p, len, uid) == 0) |
@@ -3071,7 +3070,7 @@ static int decode_attr_group(struct xdr_stream *xdr, uint32_t *bitmap, struct nf | |||
3071 | return -EIO; | 3070 | return -EIO; |
3072 | if (likely(bitmap[1] & FATTR4_WORD1_OWNER_GROUP)) { | 3071 | if (likely(bitmap[1] & FATTR4_WORD1_OWNER_GROUP)) { |
3073 | READ_BUF(4); | 3072 | READ_BUF(4); |
3074 | READ32(len); | 3073 | len = be32_to_cpup(p++); |
3075 | READ_BUF(len); | 3074 | READ_BUF(len); |
3076 | if (len < XDR_MAX_NETOBJ) { | 3075 | if (len < XDR_MAX_NETOBJ) { |
3077 | if (nfs_map_group_to_gid(clp, (char *)p, len, gid) == 0) | 3076 | if (nfs_map_group_to_gid(clp, (char *)p, len, gid) == 0) |
@@ -3101,8 +3100,8 @@ static int decode_attr_rdev(struct xdr_stream *xdr, uint32_t *bitmap, dev_t *rde | |||
3101 | dev_t tmp; | 3100 | dev_t tmp; |
3102 | 3101 | ||
3103 | READ_BUF(8); | 3102 | READ_BUF(8); |
3104 | READ32(major); | 3103 | major = be32_to_cpup(p++); |
3105 | READ32(minor); | 3104 | minor = be32_to_cpup(p++); |
3106 | tmp = MKDEV(major, minor); | 3105 | tmp = MKDEV(major, minor); |
3107 | if (MAJOR(tmp) == major && MINOR(tmp) == minor) | 3106 | if (MAJOR(tmp) == major && MINOR(tmp) == minor) |
3108 | *rdev = tmp; | 3107 | *rdev = tmp; |
@@ -3191,7 +3190,7 @@ static int decode_attr_time(struct xdr_stream *xdr, struct timespec *time) | |||
3191 | 3190 | ||
3192 | READ_BUF(12); | 3191 | READ_BUF(12); |
3193 | READ64(sec); | 3192 | READ64(sec); |
3194 | READ32(nsec); | 3193 | nsec = be32_to_cpup(p++); |
3195 | time->tv_sec = (time_t)sec; | 3194 | time->tv_sec = (time_t)sec; |
3196 | time->tv_nsec = (long)nsec; | 3195 | time->tv_nsec = (long)nsec; |
3197 | return 0; | 3196 | return 0; |
@@ -3273,7 +3272,7 @@ static int decode_change_info(struct xdr_stream *xdr, struct nfs4_change_info *c | |||
3273 | __be32 *p; | 3272 | __be32 *p; |
3274 | 3273 | ||
3275 | READ_BUF(20); | 3274 | READ_BUF(20); |
3276 | READ32(cinfo->atomic); | 3275 | cinfo->atomic = be32_to_cpup(p++); |
3277 | READ64(cinfo->before); | 3276 | READ64(cinfo->before); |
3278 | READ64(cinfo->after); | 3277 | READ64(cinfo->after); |
3279 | return 0; | 3278 | return 0; |
@@ -3289,8 +3288,8 @@ static int decode_access(struct xdr_stream *xdr, struct nfs4_accessres *access) | |||
3289 | if (status) | 3288 | if (status) |
3290 | return status; | 3289 | return status; |
3291 | READ_BUF(8); | 3290 | READ_BUF(8); |
3292 | READ32(supp); | 3291 | supp = be32_to_cpup(p++); |
3293 | READ32(acc); | 3292 | acc = be32_to_cpup(p++); |
3294 | access->supported = supp; | 3293 | access->supported = supp; |
3295 | access->access = acc; | 3294 | access->access = acc; |
3296 | return 0; | 3295 | return 0; |
@@ -3336,7 +3335,7 @@ static int decode_create(struct xdr_stream *xdr, struct nfs4_change_info *cinfo) | |||
3336 | if ((status = decode_change_info(xdr, cinfo))) | 3335 | if ((status = decode_change_info(xdr, cinfo))) |
3337 | return status; | 3336 | return status; |
3338 | READ_BUF(4); | 3337 | READ_BUF(4); |
3339 | READ32(bmlen); | 3338 | bmlen = be32_to_cpup(p++); |
3340 | READ_BUF(bmlen << 2); | 3339 | READ_BUF(bmlen << 2); |
3341 | return 0; | 3340 | return 0; |
3342 | } | 3341 | } |
@@ -3591,7 +3590,7 @@ static int decode_getfh(struct xdr_stream *xdr, struct nfs_fh *fh) | |||
3591 | return status; | 3590 | return status; |
3592 | 3591 | ||
3593 | READ_BUF(4); | 3592 | READ_BUF(4); |
3594 | READ32(len); | 3593 | len = be32_to_cpup(p++); |
3595 | if (len > NFS4_FHSIZE) | 3594 | if (len > NFS4_FHSIZE) |
3596 | return -EIO; | 3595 | return -EIO; |
3597 | fh->size = len; | 3596 | fh->size = len; |
@@ -3622,7 +3621,7 @@ static int decode_lock_denied (struct xdr_stream *xdr, struct file_lock *fl) | |||
3622 | READ_BUF(32); | 3621 | READ_BUF(32); |
3623 | READ64(offset); | 3622 | READ64(offset); |
3624 | READ64(length); | 3623 | READ64(length); |
3625 | READ32(type); | 3624 | type = be32_to_cpup(p++); |
3626 | if (fl != NULL) { | 3625 | if (fl != NULL) { |
3627 | fl->fl_start = (loff_t)offset; | 3626 | fl->fl_start = (loff_t)offset; |
3628 | fl->fl_end = fl->fl_start + (loff_t)length - 1; | 3627 | fl->fl_end = fl->fl_start + (loff_t)length - 1; |
@@ -3634,7 +3633,7 @@ static int decode_lock_denied (struct xdr_stream *xdr, struct file_lock *fl) | |||
3634 | fl->fl_pid = 0; | 3633 | fl->fl_pid = 0; |
3635 | } | 3634 | } |
3636 | READ64(clientid); | 3635 | READ64(clientid); |
3637 | READ32(namelen); | 3636 | namelen = be32_to_cpup(p++); |
3638 | READ_BUF(namelen); | 3637 | READ_BUF(namelen); |
3639 | return -NFS4ERR_DENIED; | 3638 | return -NFS4ERR_DENIED; |
3640 | } | 3639 | } |
@@ -3695,14 +3694,14 @@ static int decode_space_limit(struct xdr_stream *xdr, u64 *maxsize) | |||
3695 | uint32_t limit_type, nblocks, blocksize; | 3694 | uint32_t limit_type, nblocks, blocksize; |
3696 | 3695 | ||
3697 | READ_BUF(12); | 3696 | READ_BUF(12); |
3698 | READ32(limit_type); | 3697 | limit_type = be32_to_cpup(p++); |
3699 | switch (limit_type) { | 3698 | switch (limit_type) { |
3700 | case 1: | 3699 | case 1: |
3701 | READ64(*maxsize); | 3700 | READ64(*maxsize); |
3702 | break; | 3701 | break; |
3703 | case 2: | 3702 | case 2: |
3704 | READ32(nblocks); | 3703 | nblocks = be32_to_cpup(p++); |
3705 | READ32(blocksize); | 3704 | blocksize = be32_to_cpup(p++); |
3706 | *maxsize = (uint64_t)nblocks * (uint64_t)blocksize; | 3705 | *maxsize = (uint64_t)nblocks * (uint64_t)blocksize; |
3707 | } | 3706 | } |
3708 | return 0; | 3707 | return 0; |
@@ -3714,14 +3713,14 @@ static int decode_delegation(struct xdr_stream *xdr, struct nfs_openres *res) | |||
3714 | uint32_t delegation_type; | 3713 | uint32_t delegation_type; |
3715 | 3714 | ||
3716 | READ_BUF(4); | 3715 | READ_BUF(4); |
3717 | READ32(delegation_type); | 3716 | delegation_type = be32_to_cpup(p++); |
3718 | if (delegation_type == NFS4_OPEN_DELEGATE_NONE) { | 3717 | if (delegation_type == NFS4_OPEN_DELEGATE_NONE) { |
3719 | res->delegation_type = 0; | 3718 | res->delegation_type = 0; |
3720 | return 0; | 3719 | return 0; |
3721 | } | 3720 | } |
3722 | READ_BUF(NFS4_STATEID_SIZE+4); | 3721 | READ_BUF(NFS4_STATEID_SIZE+4); |
3723 | COPYMEM(res->delegation.data, NFS4_STATEID_SIZE); | 3722 | COPYMEM(res->delegation.data, NFS4_STATEID_SIZE); |
3724 | READ32(res->do_recall); | 3723 | res->do_recall = be32_to_cpup(p++); |
3725 | 3724 | ||
3726 | switch (delegation_type) { | 3725 | switch (delegation_type) { |
3727 | case NFS4_OPEN_DELEGATE_READ: | 3726 | case NFS4_OPEN_DELEGATE_READ: |
@@ -3752,15 +3751,15 @@ static int decode_open(struct xdr_stream *xdr, struct nfs_openres *res) | |||
3752 | decode_change_info(xdr, &res->cinfo); | 3751 | decode_change_info(xdr, &res->cinfo); |
3753 | 3752 | ||
3754 | READ_BUF(8); | 3753 | READ_BUF(8); |
3755 | READ32(res->rflags); | 3754 | res->rflags = be32_to_cpup(p++); |
3756 | READ32(bmlen); | 3755 | bmlen = be32_to_cpup(p++); |
3757 | if (bmlen > 10) | 3756 | if (bmlen > 10) |
3758 | goto xdr_error; | 3757 | goto xdr_error; |
3759 | 3758 | ||
3760 | READ_BUF(bmlen << 2); | 3759 | READ_BUF(bmlen << 2); |
3761 | savewords = min_t(uint32_t, bmlen, NFS4_BITMAP_SIZE); | 3760 | savewords = min_t(uint32_t, bmlen, NFS4_BITMAP_SIZE); |
3762 | for (i = 0; i < savewords; ++i) | 3761 | for (i = 0; i < savewords; ++i) |
3763 | READ32(res->attrset[i]); | 3762 | res->attrset[i] = be32_to_cpup(p++); |
3764 | for (; i < NFS4_BITMAP_SIZE; i++) | 3763 | for (; i < NFS4_BITMAP_SIZE; i++) |
3765 | res->attrset[i] = 0; | 3764 | res->attrset[i] = 0; |
3766 | 3765 | ||
@@ -3821,8 +3820,8 @@ static int decode_read(struct xdr_stream *xdr, struct rpc_rqst *req, struct nfs_ | |||
3821 | if (status) | 3820 | if (status) |
3822 | return status; | 3821 | return status; |
3823 | READ_BUF(8); | 3822 | READ_BUF(8); |
3824 | READ32(eof); | 3823 | eof = be32_to_cpup(p++); |
3825 | READ32(count); | 3824 | count = be32_to_cpup(p++); |
3826 | hdrlen = (u8 *) p - (u8 *) iov->iov_base; | 3825 | hdrlen = (u8 *) p - (u8 *) iov->iov_base; |
3827 | recvd = req->rq_rcv_buf.len - hdrlen; | 3826 | recvd = req->rq_rcv_buf.len - hdrlen; |
3828 | if (count > recvd) { | 3827 | if (count > recvd) { |
@@ -3948,7 +3947,7 @@ static int decode_readlink(struct xdr_stream *xdr, struct rpc_rqst *req) | |||
3948 | 3947 | ||
3949 | /* Convert length of symlink */ | 3948 | /* Convert length of symlink */ |
3950 | READ_BUF(4); | 3949 | READ_BUF(4); |
3951 | READ32(len); | 3950 | len = be32_to_cpup(p++); |
3952 | if (len >= rcvbuf->page_len || len <= 0) { | 3951 | if (len >= rcvbuf->page_len || len <= 0) { |
3953 | dprintk("nfs: server returned giant symlink!\n"); | 3952 | dprintk("nfs: server returned giant symlink!\n"); |
3954 | return -ENAMETOOLONG; | 3953 | return -ENAMETOOLONG; |
@@ -4070,7 +4069,7 @@ static int decode_setattr(struct xdr_stream *xdr) | |||
4070 | if (status) | 4069 | if (status) |
4071 | return status; | 4070 | return status; |
4072 | READ_BUF(4); | 4071 | READ_BUF(4); |
4073 | READ32(bmlen); | 4072 | bmlen = be32_to_cpup(p++); |
4074 | READ_BUF(bmlen << 2); | 4073 | READ_BUF(bmlen << 2); |
4075 | return 0; | 4074 | return 0; |
4076 | } | 4075 | } |
@@ -4082,13 +4081,13 @@ static int decode_setclientid(struct xdr_stream *xdr, struct nfs_client *clp) | |||
4082 | int32_t nfserr; | 4081 | int32_t nfserr; |
4083 | 4082 | ||
4084 | READ_BUF(8); | 4083 | READ_BUF(8); |
4085 | READ32(opnum); | 4084 | opnum = be32_to_cpup(p++); |
4086 | if (opnum != OP_SETCLIENTID) { | 4085 | if (opnum != OP_SETCLIENTID) { |
4087 | dprintk("nfs: decode_setclientid: Server returned operation" | 4086 | dprintk("nfs: decode_setclientid: Server returned operation" |
4088 | " %d\n", opnum); | 4087 | " %d\n", opnum); |
4089 | return -EIO; | 4088 | return -EIO; |
4090 | } | 4089 | } |
4091 | READ32(nfserr); | 4090 | nfserr = be32_to_cpup(p++); |
4092 | if (nfserr == NFS_OK) { | 4091 | if (nfserr == NFS_OK) { |
4093 | READ_BUF(8 + NFS4_VERIFIER_SIZE); | 4092 | READ_BUF(8 + NFS4_VERIFIER_SIZE); |
4094 | READ64(clp->cl_clientid); | 4093 | READ64(clp->cl_clientid); |
@@ -4098,12 +4097,12 @@ static int decode_setclientid(struct xdr_stream *xdr, struct nfs_client *clp) | |||
4098 | 4097 | ||
4099 | /* skip netid string */ | 4098 | /* skip netid string */ |
4100 | READ_BUF(4); | 4099 | READ_BUF(4); |
4101 | READ32(len); | 4100 | len = be32_to_cpup(p++); |
4102 | READ_BUF(len); | 4101 | READ_BUF(len); |
4103 | 4102 | ||
4104 | /* skip uaddr string */ | 4103 | /* skip uaddr string */ |
4105 | READ_BUF(4); | 4104 | READ_BUF(4); |
4106 | READ32(len); | 4105 | len = be32_to_cpup(p++); |
4107 | READ_BUF(len); | 4106 | READ_BUF(len); |
4108 | return -NFSERR_CLID_INUSE; | 4107 | return -NFSERR_CLID_INUSE; |
4109 | } else | 4108 | } else |
@@ -4127,8 +4126,8 @@ static int decode_write(struct xdr_stream *xdr, struct nfs_writeres *res) | |||
4127 | return status; | 4126 | return status; |
4128 | 4127 | ||
4129 | READ_BUF(16); | 4128 | READ_BUF(16); |
4130 | READ32(res->count); | 4129 | res->count = be32_to_cpup(p++); |
4131 | READ32(res->verf->committed); | 4130 | res->verf->committed = be32_to_cpup(p++); |
4132 | COPYMEM(res->verf->verifier, 8); | 4131 | COPYMEM(res->verf->verifier, 8); |
4133 | return 0; | 4132 | return 0; |
4134 | } | 4133 | } |
@@ -4154,11 +4153,11 @@ static int decode_exchange_id(struct xdr_stream *xdr, | |||
4154 | READ_BUF(8); | 4153 | READ_BUF(8); |
4155 | READ64(clp->cl_ex_clid); | 4154 | READ64(clp->cl_ex_clid); |
4156 | READ_BUF(12); | 4155 | READ_BUF(12); |
4157 | READ32(clp->cl_seqid); | 4156 | clp->cl_seqid = be32_to_cpup(p++); |
4158 | READ32(clp->cl_exchange_flags); | 4157 | clp->cl_exchange_flags = be32_to_cpup(p++); |
4159 | 4158 | ||
4160 | /* We ask for SP4_NONE */ | 4159 | /* We ask for SP4_NONE */ |
4161 | READ32(dummy); | 4160 | dummy = be32_to_cpup(p++); |
4162 | if (dummy != SP4_NONE) | 4161 | if (dummy != SP4_NONE) |
4163 | return -EIO; | 4162 | return -EIO; |
4164 | 4163 | ||
@@ -4167,17 +4166,17 @@ static int decode_exchange_id(struct xdr_stream *xdr, | |||
4167 | 4166 | ||
4168 | /* Throw away Major id */ | 4167 | /* Throw away Major id */ |
4169 | READ_BUF(4); | 4168 | READ_BUF(4); |
4170 | READ32(dummy); | 4169 | dummy = be32_to_cpup(p++); |
4171 | READ_BUF(dummy); | 4170 | READ_BUF(dummy); |
4172 | 4171 | ||
4173 | /* Throw away server_scope */ | 4172 | /* Throw away server_scope */ |
4174 | READ_BUF(4); | 4173 | READ_BUF(4); |
4175 | READ32(dummy); | 4174 | dummy = be32_to_cpup(p++); |
4176 | READ_BUF(dummy); | 4175 | READ_BUF(dummy); |
4177 | 4176 | ||
4178 | /* Throw away Implementation id array */ | 4177 | /* Throw away Implementation id array */ |
4179 | READ_BUF(4); | 4178 | READ_BUF(4); |
4180 | READ32(dummy); | 4179 | dummy = be32_to_cpup(p++); |
4181 | READ_BUF(dummy); | 4180 | READ_BUF(dummy); |
4182 | 4181 | ||
4183 | return 0; | 4182 | return 0; |
@@ -4190,13 +4189,13 @@ static int decode_chan_attrs(struct xdr_stream *xdr, | |||
4190 | u32 nr_attrs; | 4189 | u32 nr_attrs; |
4191 | 4190 | ||
4192 | READ_BUF(28); | 4191 | READ_BUF(28); |
4193 | READ32(attrs->headerpadsz); | 4192 | attrs->headerpadsz = be32_to_cpup(p++); |
4194 | READ32(attrs->max_rqst_sz); | 4193 | attrs->max_rqst_sz = be32_to_cpup(p++); |
4195 | READ32(attrs->max_resp_sz); | 4194 | attrs->max_resp_sz = be32_to_cpup(p++); |
4196 | READ32(attrs->max_resp_sz_cached); | 4195 | attrs->max_resp_sz_cached = be32_to_cpup(p++); |
4197 | READ32(attrs->max_ops); | 4196 | attrs->max_ops = be32_to_cpup(p++); |
4198 | READ32(attrs->max_reqs); | 4197 | attrs->max_reqs = be32_to_cpup(p++); |
4199 | READ32(nr_attrs); | 4198 | nr_attrs = be32_to_cpup(p++); |
4200 | if (unlikely(nr_attrs > 1)) { | 4199 | if (unlikely(nr_attrs > 1)) { |
4201 | printk(KERN_WARNING "%s: Invalid rdma channel attrs count %u\n", | 4200 | printk(KERN_WARNING "%s: Invalid rdma channel attrs count %u\n", |
4202 | __func__, nr_attrs); | 4201 | __func__, nr_attrs); |
@@ -4226,8 +4225,8 @@ static int decode_create_session(struct xdr_stream *xdr, | |||
4226 | 4225 | ||
4227 | /* seqid, flags */ | 4226 | /* seqid, flags */ |
4228 | READ_BUF(8); | 4227 | READ_BUF(8); |
4229 | READ32(clp->cl_seqid); | 4228 | clp->cl_seqid = be32_to_cpup(p++); |
4230 | READ32(session->flags); | 4229 | session->flags = be32_to_cpup(p++); |
4231 | 4230 | ||
4232 | /* Channel attributes */ | 4231 | /* Channel attributes */ |
4233 | status = decode_chan_attrs(xdr, &session->fc_attrs); | 4232 | status = decode_chan_attrs(xdr, &session->fc_attrs); |
@@ -4275,23 +4274,23 @@ static int decode_sequence(struct xdr_stream *xdr, | |||
4275 | goto out_err; | 4274 | goto out_err; |
4276 | } | 4275 | } |
4277 | /* seqid */ | 4276 | /* seqid */ |
4278 | READ32(dummy); | 4277 | dummy = be32_to_cpup(p++); |
4279 | if (dummy != slot->seq_nr) { | 4278 | if (dummy != slot->seq_nr) { |
4280 | dprintk("%s Invalid sequence number\n", __func__); | 4279 | dprintk("%s Invalid sequence number\n", __func__); |
4281 | goto out_err; | 4280 | goto out_err; |
4282 | } | 4281 | } |
4283 | /* slot id */ | 4282 | /* slot id */ |
4284 | READ32(dummy); | 4283 | dummy = be32_to_cpup(p++); |
4285 | if (dummy != res->sr_slotid) { | 4284 | if (dummy != res->sr_slotid) { |
4286 | dprintk("%s Invalid slot id\n", __func__); | 4285 | dprintk("%s Invalid slot id\n", __func__); |
4287 | goto out_err; | 4286 | goto out_err; |
4288 | } | 4287 | } |
4289 | /* highest slot id - currently not processed */ | 4288 | /* highest slot id - currently not processed */ |
4290 | READ32(dummy); | 4289 | dummy = be32_to_cpup(p++); |
4291 | /* target highest slot id - currently not processed */ | 4290 | /* target highest slot id - currently not processed */ |
4292 | READ32(dummy); | 4291 | dummy = be32_to_cpup(p++); |
4293 | /* result flags - currently not processed */ | 4292 | /* result flags - currently not processed */ |
4294 | READ32(dummy); | 4293 | dummy = be32_to_cpup(p++); |
4295 | status = 0; | 4294 | status = 0; |
4296 | out_err: | 4295 | out_err: |
4297 | res->sr_status = status; | 4296 | res->sr_status = status; |