Re: [PATCH 3/4] ksmbd: add support for smb2 max credit parameter

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



2021년 12월 31일 (금) 오전 2:55, Namjae Jeon <linkinjeon@xxxxxxxxxx>님이 작성:
>
> Add smb2 max credits parameter to adjust maximum credits value to limit
> number of outstanding requests.
>
> Signed-off-by: Namjae Jeon <linkinjeon@xxxxxxxxxx>

Acked-by: Hyunchul Lee <hyc.lee@xxxxxxxxx>

> ---
>  fs/ksmbd/connection.h    |  1 -
>  fs/ksmbd/ksmbd_netlink.h |  1 +
>  fs/ksmbd/smb2misc.c      |  2 +-
>  fs/ksmbd/smb2ops.c       | 16 ++++++++++++----
>  fs/ksmbd/smb2pdu.c       |  8 ++++----
>  fs/ksmbd/smb2pdu.h       |  1 +
>  fs/ksmbd/smb_common.h    |  1 +
>  fs/ksmbd/transport_ipc.c |  2 ++
>  8 files changed, 22 insertions(+), 10 deletions(-)
>
> diff --git a/fs/ksmbd/connection.h b/fs/ksmbd/connection.h
> index 72dfd155b5bf..42ffb6d9c5d8 100644
> --- a/fs/ksmbd/connection.h
> +++ b/fs/ksmbd/connection.h
> @@ -62,7 +62,6 @@ struct ksmbd_conn {
>         /* References which are made for this Server object*/
>         atomic_t                        r_count;
>         unsigned short                  total_credits;
> -       unsigned short                  max_credits;
>         spinlock_t                      credits_lock;
>         wait_queue_head_t               req_running_q;
>         /* Lock to protect requests list*/
> diff --git a/fs/ksmbd/ksmbd_netlink.h b/fs/ksmbd/ksmbd_netlink.h
> index c6718a05d347..a5c2861792ae 100644
> --- a/fs/ksmbd/ksmbd_netlink.h
> +++ b/fs/ksmbd/ksmbd_netlink.h
> @@ -103,6 +103,7 @@ struct ksmbd_startup_request {
>                                          * we set the SPARSE_FILES bit (0x40).
>                                          */
>         __u32   sub_auth[3];            /* Subauth value for Security ID */
> +       __u32   smb2_max_credits;       /* MAX credits */
>         __u32   ifc_list_sz;            /* interfaces list size */
>         __s8    ____payload[];
>  };
> diff --git a/fs/ksmbd/smb2misc.c b/fs/ksmbd/smb2misc.c
> index 50d0b1022289..6892d1822269 100644
> --- a/fs/ksmbd/smb2misc.c
> +++ b/fs/ksmbd/smb2misc.c
> @@ -326,7 +326,7 @@ static int smb2_validate_credit_charge(struct ksmbd_conn *conn,
>                 ksmbd_debug(SMB, "Insufficient credit charge, given: %d, needed: %d\n",
>                             credit_charge, calc_credit_num);
>                 return 1;
> -       } else if (credit_charge > conn->max_credits) {
> +       } else if (credit_charge > conn->vals->max_credits) {
>                 ksmbd_debug(SMB, "Too large credit charge: %d\n", credit_charge);
>                 return 1;
>         }
> diff --git a/fs/ksmbd/smb2ops.c b/fs/ksmbd/smb2ops.c
> index 02a44d28bdaf..ab23da2120b9 100644
> --- a/fs/ksmbd/smb2ops.c
> +++ b/fs/ksmbd/smb2ops.c
> @@ -19,6 +19,7 @@ static struct smb_version_values smb21_server_values = {
>         .max_read_size = SMB21_DEFAULT_IOSIZE,
>         .max_write_size = SMB21_DEFAULT_IOSIZE,
>         .max_trans_size = SMB21_DEFAULT_IOSIZE,
> +       .max_credits = SMB2_MAX_CREDITS,
>         .large_lock_type = 0,
>         .exclusive_lock_type = SMB2_LOCKFLAG_EXCLUSIVE,
>         .shared_lock_type = SMB2_LOCKFLAG_SHARED,
> @@ -44,6 +45,7 @@ static struct smb_version_values smb30_server_values = {
>         .max_read_size = SMB3_DEFAULT_IOSIZE,
>         .max_write_size = SMB3_DEFAULT_IOSIZE,
>         .max_trans_size = SMB3_DEFAULT_TRANS_SIZE,
> +       .max_credits = SMB2_MAX_CREDITS,
>         .large_lock_type = 0,
>         .exclusive_lock_type = SMB2_LOCKFLAG_EXCLUSIVE,
>         .shared_lock_type = SMB2_LOCKFLAG_SHARED,
> @@ -70,6 +72,7 @@ static struct smb_version_values smb302_server_values = {
>         .max_read_size = SMB3_DEFAULT_IOSIZE,
>         .max_write_size = SMB3_DEFAULT_IOSIZE,
>         .max_trans_size = SMB3_DEFAULT_TRANS_SIZE,
> +       .max_credits = SMB2_MAX_CREDITS,
>         .large_lock_type = 0,
>         .exclusive_lock_type = SMB2_LOCKFLAG_EXCLUSIVE,
>         .shared_lock_type = SMB2_LOCKFLAG_SHARED,
> @@ -96,6 +99,7 @@ static struct smb_version_values smb311_server_values = {
>         .max_read_size = SMB3_DEFAULT_IOSIZE,
>         .max_write_size = SMB3_DEFAULT_IOSIZE,
>         .max_trans_size = SMB3_DEFAULT_TRANS_SIZE,
> +       .max_credits = SMB2_MAX_CREDITS,
>         .large_lock_type = 0,
>         .exclusive_lock_type = SMB2_LOCKFLAG_EXCLUSIVE,
>         .shared_lock_type = SMB2_LOCKFLAG_SHARED,
> @@ -197,7 +201,6 @@ void init_smb2_1_server(struct ksmbd_conn *conn)
>         conn->ops = &smb2_0_server_ops;
>         conn->cmds = smb2_0_server_cmds;
>         conn->max_cmds = ARRAY_SIZE(smb2_0_server_cmds);
> -       conn->max_credits = SMB2_MAX_CREDITS;
>         conn->signing_algorithm = SIGNING_ALG_HMAC_SHA256_LE;
>
>         if (server_conf.flags & KSMBD_GLOBAL_FLAG_SMB2_LEASES)
> @@ -215,7 +218,6 @@ void init_smb3_0_server(struct ksmbd_conn *conn)
>         conn->ops = &smb3_0_server_ops;
>         conn->cmds = smb2_0_server_cmds;
>         conn->max_cmds = ARRAY_SIZE(smb2_0_server_cmds);
> -       conn->max_credits = SMB2_MAX_CREDITS;
>         conn->signing_algorithm = SIGNING_ALG_AES_CMAC_LE;
>
>         if (server_conf.flags & KSMBD_GLOBAL_FLAG_SMB2_LEASES)
> @@ -240,7 +242,6 @@ void init_smb3_02_server(struct ksmbd_conn *conn)
>         conn->ops = &smb3_0_server_ops;
>         conn->cmds = smb2_0_server_cmds;
>         conn->max_cmds = ARRAY_SIZE(smb2_0_server_cmds);
> -       conn->max_credits = SMB2_MAX_CREDITS;
>         conn->signing_algorithm = SIGNING_ALG_AES_CMAC_LE;
>
>         if (server_conf.flags & KSMBD_GLOBAL_FLAG_SMB2_LEASES)
> @@ -265,7 +266,6 @@ int init_smb3_11_server(struct ksmbd_conn *conn)
>         conn->ops = &smb3_11_server_ops;
>         conn->cmds = smb2_0_server_cmds;
>         conn->max_cmds = ARRAY_SIZE(smb2_0_server_cmds);
> -       conn->max_credits = SMB2_MAX_CREDITS;
>         conn->signing_algorithm = SIGNING_ALG_AES_CMAC_LE;
>
>         if (server_conf.flags & KSMBD_GLOBAL_FLAG_SMB2_LEASES)
> @@ -304,3 +304,11 @@ void init_smb2_max_trans_size(unsigned int sz)
>         smb302_server_values.max_trans_size = sz;
>         smb311_server_values.max_trans_size = sz;
>  }
> +
> +void init_smb2_max_credits(unsigned int sz)
> +{
> +       smb21_server_values.max_credits = sz;
> +       smb30_server_values.max_credits = sz;
> +       smb302_server_values.max_credits = sz;
> +       smb311_server_values.max_credits = sz;
> +}
> diff --git a/fs/ksmbd/smb2pdu.c b/fs/ksmbd/smb2pdu.c
> index b00108921bbb..860fe3a03ad7 100644
> --- a/fs/ksmbd/smb2pdu.c
> +++ b/fs/ksmbd/smb2pdu.c
> @@ -308,7 +308,7 @@ int smb2_set_rsp_credits(struct ksmbd_work *work)
>
>         hdr->CreditCharge = req_hdr->CreditCharge;
>
> -       if (conn->total_credits > conn->max_credits) {
> +       if (conn->total_credits > conn->vals->max_credits) {
>                 hdr->CreditRequest = 0;
>                 pr_err("Total credits overflow: %d\n", conn->total_credits);
>                 return -EINVAL;
> @@ -329,12 +329,12 @@ int smb2_set_rsp_credits(struct ksmbd_work *work)
>         if (hdr->Command == SMB2_NEGOTIATE)
>                 aux_max = 0;
>         else
> -               aux_max = conn->max_credits - credit_charge;
> +               aux_max = conn->vals->max_credits - credit_charge;
>         aux_credits = min_t(unsigned short, aux_credits, aux_max);
>         credits_granted = credit_charge + aux_credits;
>
> -       if (conn->max_credits - conn->total_credits < credits_granted)
> -               credits_granted = conn->max_credits -
> +       if (conn->vals->max_credits - conn->total_credits < credits_granted)
> +               credits_granted = conn->vals->max_credits -
>                         conn->total_credits;
>
>         conn->total_credits += credits_granted;
> diff --git a/fs/ksmbd/smb2pdu.h b/fs/ksmbd/smb2pdu.h
> index 4a3e4339d4c4..725b800c29c8 100644
> --- a/fs/ksmbd/smb2pdu.h
> +++ b/fs/ksmbd/smb2pdu.h
> @@ -980,6 +980,7 @@ int init_smb3_11_server(struct ksmbd_conn *conn);
>  void init_smb2_max_read_size(unsigned int sz);
>  void init_smb2_max_write_size(unsigned int sz);
>  void init_smb2_max_trans_size(unsigned int sz);
> +void init_smb2_max_credits(unsigned int sz);
>
>  bool is_smb2_neg_cmd(struct ksmbd_work *work);
>  bool is_smb2_rsp(struct ksmbd_work *work);
> diff --git a/fs/ksmbd/smb_common.h b/fs/ksmbd/smb_common.h
> index 50590842b651..e1369b4345a9 100644
> --- a/fs/ksmbd/smb_common.h
> +++ b/fs/ksmbd/smb_common.h
> @@ -365,6 +365,7 @@ struct smb_version_values {
>         __u32           max_read_size;
>         __u32           max_write_size;
>         __u32           max_trans_size;
> +       __u32           max_credits;
>         __u32           large_lock_type;
>         __u32           exclusive_lock_type;
>         __u32           shared_lock_type;
> diff --git a/fs/ksmbd/transport_ipc.c b/fs/ksmbd/transport_ipc.c
> index 1acf1892a466..3ad6881e0f7e 100644
> --- a/fs/ksmbd/transport_ipc.c
> +++ b/fs/ksmbd/transport_ipc.c
> @@ -301,6 +301,8 @@ static int ipc_server_config_on_startup(struct ksmbd_startup_request *req)
>                 init_smb2_max_write_size(req->smb2_max_write);
>         if (req->smb2_max_trans)
>                 init_smb2_max_trans_size(req->smb2_max_trans);
> +       if (req->smb2_max_credits)
> +               init_smb2_max_credits(req->smb2_max_credits);
>
>         ret = ksmbd_set_netbios_name(req->netbios_name);
>         ret |= ksmbd_set_server_string(req->server_string);
> --
> 2.25.1
>


-- 
Thanks,
Hyunchul




[Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux