mirror of
https://github.com/torvalds/linux.git
synced 2024-11-15 16:41:58 +00:00
nfs41: Verify channel's attributes accordingly to RFC v2
ca_maxoperations: For the backchannel, the server MUST NOT change the value the client offers. For the fore channel, the server MAY change the requested value. ca_maxrequests: For the backchannel, the server MUST NOT change the value the client offers. For the fore channel, the server MAY change the requested value. Signed-off-by: Vitaliy Gusev <gusev.vitaliy@nexenta.com> Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
This commit is contained in:
parent
571b755401
commit
b4b9a0c1c8
@ -5287,6 +5287,8 @@ static int nfs4_verify_fore_channel_attrs(struct nfs41_create_session_args *args
|
||||
return -EINVAL;
|
||||
if (rcvd->max_reqs == 0)
|
||||
return -EINVAL;
|
||||
if (rcvd->max_reqs > NFS4_MAX_SLOT_TABLE)
|
||||
rcvd->max_reqs = NFS4_MAX_SLOT_TABLE;
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -5302,9 +5304,9 @@ static int nfs4_verify_back_channel_attrs(struct nfs41_create_session_args *args
|
||||
if (rcvd->max_resp_sz_cached > sent->max_resp_sz_cached)
|
||||
return -EINVAL;
|
||||
/* These would render the backchannel useless: */
|
||||
if (rcvd->max_ops == 0)
|
||||
if (rcvd->max_ops != sent->max_ops)
|
||||
return -EINVAL;
|
||||
if (rcvd->max_reqs == 0)
|
||||
if (rcvd->max_reqs != sent->max_reqs)
|
||||
return -EINVAL;
|
||||
return 0;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user