diff options
author | Chuck Lever <chuck.lever@oracle.com> | 2010-12-14 09:57:02 -0500 |
---|---|---|
committer | Trond Myklebust <Trond.Myklebust@netapp.com> | 2010-12-16 12:37:23 -0500 |
commit | f6048709391336cf27fb5c1cfca8e792103e5a73 (patch) | |
tree | 6968f15effa7769248faed8938a9aae0ba29a15d /fs/nfs/nfs3xdr.c | |
parent | b2cdd9c9c95e0e389a8b75fe25f266fc5267bbb6 (diff) |
NFS: Move and update xdr_decode_foo() functions that we're keeping
Clean up.
Move the timestamp decoder to match the placement and naming
conventions of the other helpers. Fold xdr_decode_fattr() into
decode_fattr3(), which is now it's only user. Fold
xdr_decode_wcc_attr() into decode_wcc_attr(), which is now it's only
user.
Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
Tested-by: J. Bruce Fields <bfields@redhat.com>
Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
Diffstat (limited to 'fs/nfs/nfs3xdr.c')
-rw-r--r-- | fs/nfs/nfs3xdr.c | 136 |
1 files changed, 67 insertions, 69 deletions
diff --git a/fs/nfs/nfs3xdr.c b/fs/nfs/nfs3xdr.c index 586587f42fc9..c97d00fe849a 100644 --- a/fs/nfs/nfs3xdr.c +++ b/fs/nfs/nfs3xdr.c | |||
@@ -127,69 +127,6 @@ static void print_overflow_msg(const char *func, const struct xdr_stream *xdr) | |||
127 | 127 | ||
128 | 128 | ||
129 | /* | 129 | /* |
130 | * Common NFS XDR functions as inlines | ||
131 | */ | ||
132 | |||
133 | /* | ||
134 | * Encode/decode time. | ||
135 | */ | ||
136 | static inline __be32 * | ||
137 | xdr_decode_time3(__be32 *p, struct timespec *timep) | ||
138 | { | ||
139 | timep->tv_sec = ntohl(*p++); | ||
140 | timep->tv_nsec = ntohl(*p++); | ||
141 | return p; | ||
142 | } | ||
143 | |||
144 | static __be32 * | ||
145 | xdr_decode_fattr(__be32 *p, struct nfs_fattr *fattr) | ||
146 | { | ||
147 | unsigned int type, major, minor; | ||
148 | umode_t fmode; | ||
149 | |||
150 | type = ntohl(*p++); | ||
151 | if (type > NF3FIFO) | ||
152 | type = NF3NON; | ||
153 | fmode = nfs_type2fmt[type]; | ||
154 | fattr->mode = (ntohl(*p++) & ~S_IFMT) | fmode; | ||
155 | fattr->nlink = ntohl(*p++); | ||
156 | fattr->uid = ntohl(*p++); | ||
157 | fattr->gid = ntohl(*p++); | ||
158 | p = xdr_decode_hyper(p, &fattr->size); | ||
159 | p = xdr_decode_hyper(p, &fattr->du.nfs3.used); | ||
160 | |||
161 | /* Turn remote device info into Linux-specific dev_t */ | ||
162 | major = ntohl(*p++); | ||
163 | minor = ntohl(*p++); | ||
164 | fattr->rdev = MKDEV(major, minor); | ||
165 | if (MAJOR(fattr->rdev) != major || MINOR(fattr->rdev) != minor) | ||
166 | fattr->rdev = 0; | ||
167 | |||
168 | p = xdr_decode_hyper(p, &fattr->fsid.major); | ||
169 | fattr->fsid.minor = 0; | ||
170 | p = xdr_decode_hyper(p, &fattr->fileid); | ||
171 | p = xdr_decode_time3(p, &fattr->atime); | ||
172 | p = xdr_decode_time3(p, &fattr->mtime); | ||
173 | p = xdr_decode_time3(p, &fattr->ctime); | ||
174 | |||
175 | /* Update the mode bits */ | ||
176 | fattr->valid |= NFS_ATTR_FATTR_V3; | ||
177 | return p; | ||
178 | } | ||
179 | |||
180 | static inline __be32 * | ||
181 | xdr_decode_wcc_attr(__be32 *p, struct nfs_fattr *fattr) | ||
182 | { | ||
183 | p = xdr_decode_hyper(p, &fattr->pre_size); | ||
184 | p = xdr_decode_time3(p, &fattr->pre_mtime); | ||
185 | p = xdr_decode_time3(p, &fattr->pre_ctime); | ||
186 | fattr->valid |= NFS_ATTR_FATTR_PRESIZE | ||
187 | | NFS_ATTR_FATTR_PREMTIME | ||
188 | | NFS_ATTR_FATTR_PRECTIME; | ||
189 | return p; | ||
190 | } | ||
191 | |||
192 | /* | ||
193 | * Encode/decode NFSv3 basic data types | 130 | * Encode/decode NFSv3 basic data types |
194 | * | 131 | * |
195 | * Basic NFSv3 data types are defined in section 2.5 of RFC 1813: | 132 | * Basic NFSv3 data types are defined in section 2.5 of RFC 1813: |
@@ -239,6 +176,11 @@ out_overflow: | |||
239 | * | 176 | * |
240 | * typedef uint64 fileid3; | 177 | * typedef uint64 fileid3; |
241 | */ | 178 | */ |
179 | static __be32 *xdr_decode_fileid3(__be32 *p, u64 *fileid) | ||
180 | { | ||
181 | return xdr_decode_hyper(p, fileid); | ||
182 | } | ||
183 | |||
242 | static int decode_fileid3(struct xdr_stream *xdr, u64 *fileid) | 184 | static int decode_fileid3(struct xdr_stream *xdr, u64 *fileid) |
243 | { | 185 | { |
244 | return decode_uint64(xdr, fileid); | 186 | return decode_uint64(xdr, fileid); |
@@ -452,6 +394,17 @@ static void encode_ftype3(struct xdr_stream *xdr, const u32 type) | |||
452 | encode_uint32(xdr, type); | 394 | encode_uint32(xdr, type); |
453 | } | 395 | } |
454 | 396 | ||
397 | static __be32 *xdr_decode_ftype3(__be32 *p, umode_t *mode) | ||
398 | { | ||
399 | u32 type; | ||
400 | |||
401 | type = be32_to_cpup(p++); | ||
402 | if (type > NF3FIFO) | ||
403 | type = NF3NON; | ||
404 | *mode = nfs_type2fmt[type]; | ||
405 | return p; | ||
406 | } | ||
407 | |||
455 | /* | 408 | /* |
456 | * specdata3 | 409 | * specdata3 |
457 | * | 410 | * |
@@ -469,6 +422,18 @@ static void encode_specdata3(struct xdr_stream *xdr, const dev_t rdev) | |||
469 | *p = cpu_to_be32(MINOR(rdev)); | 422 | *p = cpu_to_be32(MINOR(rdev)); |
470 | } | 423 | } |
471 | 424 | ||
425 | static __be32 *xdr_decode_specdata3(__be32 *p, dev_t *rdev) | ||
426 | { | ||
427 | unsigned int major, minor; | ||
428 | |||
429 | major = be32_to_cpup(p++); | ||
430 | minor = be32_to_cpup(p++); | ||
431 | *rdev = MKDEV(major, minor); | ||
432 | if (MAJOR(*rdev) != major || MINOR(*rdev) != minor) | ||
433 | *rdev = 0; | ||
434 | return p; | ||
435 | } | ||
436 | |||
472 | /* | 437 | /* |
473 | * nfs_fh3 | 438 | * nfs_fh3 |
474 | * | 439 | * |
@@ -530,6 +495,13 @@ static __be32 *xdr_encode_nfstime3(__be32 *p, const struct timespec *timep) | |||
530 | return p; | 495 | return p; |
531 | } | 496 | } |
532 | 497 | ||
498 | static __be32 *xdr_decode_nfstime3(__be32 *p, struct timespec *timep) | ||
499 | { | ||
500 | timep->tv_sec = be32_to_cpup(p++); | ||
501 | timep->tv_nsec = be32_to_cpup(p++); | ||
502 | return p; | ||
503 | } | ||
504 | |||
533 | /* | 505 | /* |
534 | * sattr3 | 506 | * sattr3 |
535 | * | 507 | * |
@@ -678,12 +650,33 @@ static void encode_sattr3(struct xdr_stream *xdr, const struct iattr *attr) | |||
678 | */ | 650 | */ |
679 | static int decode_fattr3(struct xdr_stream *xdr, struct nfs_fattr *fattr) | 651 | static int decode_fattr3(struct xdr_stream *xdr, struct nfs_fattr *fattr) |
680 | { | 652 | { |
653 | umode_t fmode; | ||
681 | __be32 *p; | 654 | __be32 *p; |
682 | 655 | ||
683 | p = xdr_inline_decode(xdr, NFS3_fattr_sz << 2); | 656 | p = xdr_inline_decode(xdr, NFS3_fattr_sz << 2); |
684 | if (unlikely(p == NULL)) | 657 | if (unlikely(p == NULL)) |
685 | goto out_overflow; | 658 | goto out_overflow; |
686 | xdr_decode_fattr(p, fattr); | 659 | |
660 | p = xdr_decode_ftype3(p, &fmode); | ||
661 | |||
662 | fattr->mode = (be32_to_cpup(p++) & ~S_IFMT) | fmode; | ||
663 | fattr->nlink = be32_to_cpup(p++); | ||
664 | fattr->uid = be32_to_cpup(p++); | ||
665 | fattr->gid = be32_to_cpup(p++); | ||
666 | |||
667 | p = xdr_decode_size3(p, &fattr->size); | ||
668 | p = xdr_decode_size3(p, &fattr->du.nfs3.used); | ||
669 | p = xdr_decode_specdata3(p, &fattr->rdev); | ||
670 | |||
671 | p = xdr_decode_hyper(p, &fattr->fsid.major); | ||
672 | fattr->fsid.minor = 0; | ||
673 | |||
674 | p = xdr_decode_fileid3(p, &fattr->fileid); | ||
675 | p = xdr_decode_nfstime3(p, &fattr->atime); | ||
676 | p = xdr_decode_nfstime3(p, &fattr->mtime); | ||
677 | xdr_decode_nfstime3(p, &fattr->ctime); | ||
678 | |||
679 | fattr->valid |= NFS_ATTR_FATTR_V3; | ||
687 | return 0; | 680 | return 0; |
688 | out_overflow: | 681 | out_overflow: |
689 | print_overflow_msg(__func__, xdr); | 682 | print_overflow_msg(__func__, xdr); |
@@ -730,7 +723,15 @@ static int decode_wcc_attr(struct xdr_stream *xdr, struct nfs_fattr *fattr) | |||
730 | p = xdr_inline_decode(xdr, NFS3_wcc_attr_sz << 2); | 723 | p = xdr_inline_decode(xdr, NFS3_wcc_attr_sz << 2); |
731 | if (unlikely(p == NULL)) | 724 | if (unlikely(p == NULL)) |
732 | goto out_overflow; | 725 | goto out_overflow; |
733 | xdr_decode_wcc_attr(p, fattr); | 726 | |
727 | fattr->valid |= NFS_ATTR_FATTR_PRESIZE | ||
728 | | NFS_ATTR_FATTR_PREMTIME | ||
729 | | NFS_ATTR_FATTR_PRECTIME; | ||
730 | |||
731 | p = xdr_decode_size3(p, &fattr->pre_size); | ||
732 | p = xdr_decode_nfstime3(p, &fattr->pre_mtime); | ||
733 | xdr_decode_nfstime3(p, &fattr->pre_ctime); | ||
734 | |||
734 | return 0; | 735 | return 0; |
735 | out_overflow: | 736 | out_overflow: |
736 | print_overflow_msg(__func__, xdr); | 737 | print_overflow_msg(__func__, xdr); |
@@ -1009,10 +1010,7 @@ static void encode_write3args(struct xdr_stream *xdr, | |||
1009 | p = xdr_reserve_space(xdr, 8 + 4 + 4 + 4); | 1010 | p = xdr_reserve_space(xdr, 8 + 4 + 4 + 4); |
1010 | p = xdr_encode_hyper(p, args->offset); | 1011 | p = xdr_encode_hyper(p, args->offset); |
1011 | *p++ = cpu_to_be32(args->count); | 1012 | *p++ = cpu_to_be32(args->count); |
1012 | |||
1013 | BUG_ON(args->stable > NFS_FILE_SYNC); | ||
1014 | *p++ = cpu_to_be32(args->stable); | 1013 | *p++ = cpu_to_be32(args->stable); |
1015 | |||
1016 | *p = cpu_to_be32(args->count); | 1014 | *p = cpu_to_be32(args->count); |
1017 | xdr_write_pages(xdr, args->pages, args->pgbase, args->count); | 1015 | xdr_write_pages(xdr, args->pages, args->pgbase, args->count); |
1018 | } | 1016 | } |
@@ -2278,7 +2276,7 @@ static int decode_fsinfo3resok(struct xdr_stream *xdr, | |||
2278 | result->wtmult = be32_to_cpup(p++); | 2276 | result->wtmult = be32_to_cpup(p++); |
2279 | result->dtpref = be32_to_cpup(p++); | 2277 | result->dtpref = be32_to_cpup(p++); |
2280 | p = xdr_decode_size3(p, &result->maxfilesize); | 2278 | p = xdr_decode_size3(p, &result->maxfilesize); |
2281 | xdr_decode_time3(p, &result->time_delta); | 2279 | xdr_decode_nfstime3(p, &result->time_delta); |
2282 | 2280 | ||
2283 | /* ignore properties */ | 2281 | /* ignore properties */ |
2284 | result->lease_time = 0; | 2282 | result->lease_time = 0; |