Re: [PATCH v1] cifs: move large array from stack to heap

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

 



Seems like a reasonable idea - might help to show which stack space
warning it addresses, and whether considered important enough, or can
wait for 5.1

On Mon, Jan 7, 2019 at 12:04 PM Aurelien Aptel <aaptel@xxxxxxxx> wrote:
>
> Signed-off-by: Aurelien Aptel <aaptel@xxxxxxxx>
> ---
>  fs/cifs/cifssmb.c | 23 ++++++++++++++++-------
>  fs/cifs/smb2pdu.c | 23 ++++++++++++++++-------
>  2 files changed, 32 insertions(+), 14 deletions(-)
>
> diff --git a/fs/cifs/cifssmb.c b/fs/cifs/cifssmb.c
> index b1f49c1c543a..6f60f6c5bafe 100644
> --- a/fs/cifs/cifssmb.c
> +++ b/fs/cifs/cifssmb.c
> @@ -128,24 +128,31 @@ static int __cifs_reconnect_tcon(const struct nls_table *nlsc,
>         int rc;
>         struct dfs_cache_tgt_list tl;
>         struct dfs_cache_tgt_iterator *it = NULL;
> -       char tree[MAX_TREE_SIZE + 1];
> +       char *tree;
>         const char *tcp_host;
>         size_t tcp_host_len;
>         const char *dfs_host;
>         size_t dfs_host_len;
>
> +       tree = kzalloc(MAX_TREE_SIZE + 1, GFP_KERNEL);
> +       if (!tree)
> +               return -ENOMEM;
> +
>         if (tcon->ipc) {
> -               snprintf(tree, sizeof(tree), "\\\\%s\\IPC$",
> +               snprintf(tree, MAX_TREE_SIZE, "\\\\%s\\IPC$",
>                          tcon->ses->server->hostname);
> -               return CIFSTCon(0, tcon->ses, tree, tcon, nlsc);
> +               rc = CIFSTCon(0, tcon->ses, tree, tcon, nlsc);
> +               goto out;
>         }
>
> -       if (!tcon->dfs_path)
> -               return CIFSTCon(0, tcon->ses, tcon->treeName, tcon, nlsc);
> +       if (!tcon->dfs_path) {
> +               rc = CIFSTCon(0, tcon->ses, tcon->treeName, tcon, nlsc);
> +               goto out;
> +       }
>
>         rc = dfs_cache_noreq_find(tcon->dfs_path + 1, NULL, &tl);
>         if (rc)
> -               return rc;
> +               goto out;
>
>         extract_unc_hostname(tcon->ses->server->hostname, &tcp_host,
>                              &tcp_host_len);
> @@ -165,7 +172,7 @@ static int __cifs_reconnect_tcon(const struct nls_table *nlsc,
>                         continue;
>                 }
>
> -               snprintf(tree, sizeof(tree), "\\%s", tgt);
> +               snprintf(tree, MAX_TREE_SIZE, "\\%s", tgt);
>
>                 rc = CIFSTCon(0, tcon->ses, tree, tcon, nlsc);
>                 if (!rc)
> @@ -182,6 +189,8 @@ static int __cifs_reconnect_tcon(const struct nls_table *nlsc,
>                         rc = -ENOENT;
>         }
>         dfs_cache_free_tgts(&tl);
> +out:
> +       kfree(tree);
>         return rc;
>  }
>  #else
> diff --git a/fs/cifs/smb2pdu.c b/fs/cifs/smb2pdu.c
> index e283590955cd..04a0939f7f20 100644
> --- a/fs/cifs/smb2pdu.c
> +++ b/fs/cifs/smb2pdu.c
> @@ -162,24 +162,31 @@ static int __smb2_reconnect(const struct nls_table *nlsc,
>         int rc;
>         struct dfs_cache_tgt_list tl;
>         struct dfs_cache_tgt_iterator *it = NULL;
> -       char tree[MAX_TREE_SIZE + 1];
> +       char *tree;
>         const char *tcp_host;
>         size_t tcp_host_len;
>         const char *dfs_host;
>         size_t dfs_host_len;
>
> +       tree = kzalloc(MAX_TREE_SIZE + 1, GFP_KERNEL);
> +       if (!tree)
> +               return -ENOMEM;
> +
>         if (tcon->ipc) {
> -               snprintf(tree, sizeof(tree), "\\\\%s\\IPC$",
> +               snprintf(tree, MAX_TREE_SIZE, "\\\\%s\\IPC$",
>                          tcon->ses->server->hostname);
> -               return SMB2_tcon(0, tcon->ses, tree, tcon, nlsc);
> +               rc = SMB2_tcon(0, tcon->ses, tree, tcon, nlsc);
> +               goto out;
>         }
>
> -       if (!tcon->dfs_path)
> -               return SMB2_tcon(0, tcon->ses, tcon->treeName, tcon, nlsc);
> +       if (!tcon->dfs_path) {
> +               rc = SMB2_tcon(0, tcon->ses, tcon->treeName, tcon, nlsc);
> +               goto out;
> +       }
>
>         rc = dfs_cache_noreq_find(tcon->dfs_path + 1, NULL, &tl);
>         if (rc)
> -               return rc;
> +               goto out;
>
>         extract_unc_hostname(tcon->ses->server->hostname, &tcp_host,
>                              &tcp_host_len);
> @@ -199,7 +206,7 @@ static int __smb2_reconnect(const struct nls_table *nlsc,
>                         continue;
>                 }
>
> -               snprintf(tree, sizeof(tree), "\\%s", tgt);
> +               snprintf(tree, MAX_TREE_SIZE, "\\%s", tgt);
>
>                 rc = SMB2_tcon(0, tcon->ses, tree, tcon, nlsc);
>                 if (!rc)
> @@ -216,6 +223,8 @@ static int __smb2_reconnect(const struct nls_table *nlsc,
>                         rc = -ENOENT;
>         }
>         dfs_cache_free_tgts(&tl);
> +out:
> +       kfree(tree);
>         return rc;
>  }
>  #else
> --
> 2.16.4



-- 
Thanks,

Steve



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

  Powered by Linux