mirror of https://gitee.com/openkylin/linux.git
ksmbd: don't need 8byte alignment for request length in ksmbd_check_message
commitb53ad8107e
upstream. When validating request length in ksmbd_check_message, 8byte alignment is not needed for compound request. It can cause wrong validation of request length. Fixes:e2f34481b2
("cifsd: add server-side procedures for SMB3") Cc: stable@vger.kernel.org # v5.15 Acked-by: Hyunchul Lee <hyc.lee@gmail.com> 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:
parent
aacb2ddb67
commit
1dd578e985
|
@ -358,12 +358,10 @@ int ksmbd_smb2_check_message(struct ksmbd_work *work)
|
|||
hdr = &pdu->hdr;
|
||||
}
|
||||
|
||||
if (le32_to_cpu(hdr->NextCommand) > 0) {
|
||||
if (le32_to_cpu(hdr->NextCommand) > 0)
|
||||
len = le32_to_cpu(hdr->NextCommand);
|
||||
} else if (work->next_smb2_rcv_hdr_off) {
|
||||
else if (work->next_smb2_rcv_hdr_off)
|
||||
len -= work->next_smb2_rcv_hdr_off;
|
||||
len = round_up(len, 8);
|
||||
}
|
||||
|
||||
if (check_smb2_hdr(hdr))
|
||||
return 1;
|
||||
|
|
Loading…
Reference in New Issue