ksmbd: fix credit count leakage
commit 84c5aa47925a1f40d698b6a6a2bf67e99617433d upstream. This patch fix the failure from smb2.credits.single_req_credits_granted test. When client send 8192 credit request, ksmbd return 8191 credit granted. ksmbd should give maximum possible credits that must be granted within the range of not exceeding the max credit to client. Cc: stable@vger.kernel.org Signed-off-by: Namjae Jeon <linkinjeon@kernel.org> Signed-off-by: Steve French <stfrench@microsoft.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
8a870c07a1
commit
380b47932e
@@ -338,13 +338,9 @@ int smb2_set_rsp_credits(struct ksmbd_work *work)
|
||||
if (hdr->Command == SMB2_NEGOTIATE)
|
||||
aux_max = 1;
|
||||
else
|
||||
aux_max = conn->vals->max_credits - credit_charge;
|
||||
aux_max = conn->vals->max_credits - conn->total_credits;
|
||||
credits_granted = min_t(unsigned short, credits_requested, aux_max);
|
||||
|
||||
if (conn->vals->max_credits - conn->total_credits < credits_granted)
|
||||
credits_granted = conn->vals->max_credits -
|
||||
conn->total_credits;
|
||||
|
||||
conn->total_credits += credits_granted;
|
||||
work->credits_granted += credits_granted;
|
||||
|
||||
|
||||
Reference in New Issue
Block a user