2021년 10월 8일 (금) 오후 12:29, Namjae Jeon <linkinjeon@xxxxxxxxxx>님이 작성: > > ksmbd limit read/write/trans buffer size not to exceed > maximum stream protocol length(0x00FFFFFF). > > Cc: Tom Talpey <tom@xxxxxxxxxx> > Cc: Ronnie Sahlberg <ronniesahlberg@xxxxxxxxx> > Cc: Ralph Böhme <slow@xxxxxxxxx> > Cc: Hyunchul Lee <hyc.lee@xxxxxxxxx> > Cc: Steve French <smfrench@xxxxxxxxx> > Cc: Sergey Senozhatsky <senozhatsky@xxxxxxxxxxxx> > Signed-off-by: Namjae Jeon <linkinjeon@xxxxxxxxxx> > --- > v2: > - change 8MB limitation to MAX_STREAM_PROT_LEN. > > fs/ksmbd/smb2ops.c | 3 +++ > 1 file changed, 3 insertions(+) > > diff --git a/fs/ksmbd/smb2ops.c b/fs/ksmbd/smb2ops.c > index b06456eb587b..63289872da97 100644 > --- a/fs/ksmbd/smb2ops.c > +++ b/fs/ksmbd/smb2ops.c > @@ -284,6 +284,7 @@ int init_smb3_11_server(struct ksmbd_conn *conn) > > void init_smb2_max_read_size(unsigned int sz) > { > + sz = min_t(u32, sz, MAX_STREAM_PROT_LEN); If the maximum read size is MAX_STREAM_PROT_LEN, couldn't headers + data exceed MAX_STREAM_PROT_LEN? > smb21_server_values.max_read_size = sz; > smb30_server_values.max_read_size = sz; > smb302_server_values.max_read_size = sz; > @@ -292,6 +293,7 @@ void init_smb2_max_read_size(unsigned int sz) > > void init_smb2_max_write_size(unsigned int sz) > { > + sz = min_t(u32, sz, MAX_STREAM_PROT_LEN); > smb21_server_values.max_write_size = sz; > smb30_server_values.max_write_size = sz; > smb302_server_values.max_write_size = sz; > @@ -300,6 +302,7 @@ void init_smb2_max_write_size(unsigned int sz) > > void init_smb2_max_trans_size(unsigned int sz) > { > + sz = min_t(u32, sz, MAX_STREAM_PROT_LEN); > smb21_server_values.max_trans_size = sz; > smb30_server_values.max_trans_size = sz; > smb302_server_values.max_trans_size = sz; > -- > 2.25.1 > -- Thanks, Hyunchul