aboutsummaryrefslogtreecommitdiffstats
path: root/fs/nfsd/nfs4xdr.c
diff options
context:
space:
mode:
authorJ. Bruce Fields <bfields@redhat.com>2014-05-08 17:38:18 -0400
committerJ. Bruce Fields <bfields@redhat.com>2014-05-30 17:32:13 -0400
commitc8f13d977518e588ac89dcf8e841821569108109 (patch)
treec8406d790712b2ebe2708c9c99a1a04ce8ff434d /fs/nfsd/nfs4xdr.c
parentb042098063849794d69b5322fcc6cf9fb5f2586e (diff)
nfsd4: really fix nfs4err_resource in 4.1 case
encode_getattr, for example, can return nfserr_resource to indicate it ran out of buffer space. That's not a legal error in the 4.1 case. And in the 4.1 case, if we ran out of buffer space, we should have exceeded a session limit too. (Note in 1bc49d83c37cfaf46be357757e592711e67f9809 "nfsd4: fix nfs4err_resource in 4.1 case" we originally tried fixing this error return before fixing the problem that we could error out while we still had lots of available space. The result was to trade one illegal error for another in those cases. We decided that was helpful, so reverted the change in fc208d026be0c7d60db9118583fc62f6ca97743d, and are only reinstating it now that we've elimited almost all of those cases.) Signed-off-by: J. Bruce Fields <bfields@redhat.com>
Diffstat (limited to 'fs/nfsd/nfs4xdr.c')
-rw-r--r--fs/nfsd/nfs4xdr.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/fs/nfsd/nfs4xdr.c b/fs/nfsd/nfs4xdr.c
index 480f12c4e590..7f346d8ef267 100644
--- a/fs/nfsd/nfs4xdr.c
+++ b/fs/nfsd/nfs4xdr.c
@@ -3901,6 +3901,14 @@ nfsd4_encode_operation(struct nfsd4_compoundres *resp, struct nfsd4_op *op)
3901 space_needed = COMPOUND_ERR_SLACK_SPACE; 3901 space_needed = COMPOUND_ERR_SLACK_SPACE;
3902 op->status = nfsd4_check_resp_size(resp, space_needed); 3902 op->status = nfsd4_check_resp_size(resp, space_needed);
3903 } 3903 }
3904 if (op->status == nfserr_resource && nfsd4_has_session(&resp->cstate)) {
3905 struct nfsd4_slot *slot = resp->cstate.slot;
3906
3907 if (slot->sl_flags & NFSD4_SLOT_CACHETHIS)
3908 op->status = nfserr_rep_too_big_to_cache;
3909 else
3910 op->status = nfserr_rep_too_big;
3911 }
3904 if (op->status == nfserr_resource || 3912 if (op->status == nfserr_resource ||
3905 op->status == nfserr_rep_too_big || 3913 op->status == nfserr_rep_too_big ||
3906 op->status == nfserr_rep_too_big_to_cache) { 3914 op->status == nfserr_rep_too_big_to_cache) {