diff mbox series

smb: use crypto_shash_digest() in symlink_hash()

Message ID 20231029050300.154832-1-ebiggers@kernel.org (mailing list archive)
State Not Applicable
Delegated to: Herbert Xu
Headers show
Series smb: use crypto_shash_digest() in symlink_hash() | expand

Commit Message

Eric Biggers Oct. 29, 2023, 5:03 a.m. UTC
From: Eric Biggers <ebiggers@google.com>

Simplify symlink_hash() by using crypto_shash_digest() instead of an
init+update+final sequence.  This should also improve performance.

Signed-off-by: Eric Biggers <ebiggers@google.com>
---
 fs/smb/client/link.c | 16 ++--------------
 1 file changed, 2 insertions(+), 14 deletions(-)


base-commit: 2af9b20dbb39f6ebf9b9b6c090271594627d818e

Comments

Steve French Oct. 30, 2023, 1:10 a.m. UTC | #1
tentatively merged into cifs-2.6.git for-next pending additional testing

On Sun, Oct 29, 2023 at 12:03 AM Eric Biggers <ebiggers@kernel.org> wrote:
>
> From: Eric Biggers <ebiggers@google.com>
>
> Simplify symlink_hash() by using crypto_shash_digest() instead of an
> init+update+final sequence.  This should also improve performance.
>
> Signed-off-by: Eric Biggers <ebiggers@google.com>
> ---
>  fs/smb/client/link.c | 16 ++--------------
>  1 file changed, 2 insertions(+), 14 deletions(-)
>
> diff --git a/fs/smb/client/link.c b/fs/smb/client/link.c
> index c66be4904e1f..a1da50e66fbb 100644
> --- a/fs/smb/client/link.c
> +++ b/fs/smb/client/link.c
> @@ -35,37 +35,25 @@
>  #define CIFS_MF_SYMLINK_MD5_ARGS(md5_hash) md5_hash
>
>  static int
>  symlink_hash(unsigned int link_len, const char *link_str, u8 *md5_hash)
>  {
>         int rc;
>         struct shash_desc *md5 = NULL;
>
>         rc = cifs_alloc_hash("md5", &md5);
>         if (rc)
> -               goto symlink_hash_err;
> +               return rc;
>
> -       rc = crypto_shash_init(md5);
> -       if (rc) {
> -               cifs_dbg(VFS, "%s: Could not init md5 shash\n", __func__);
> -               goto symlink_hash_err;
> -       }
> -       rc = crypto_shash_update(md5, link_str, link_len);
> -       if (rc) {
> -               cifs_dbg(VFS, "%s: Could not update with link_str\n", __func__);
> -               goto symlink_hash_err;
> -       }
> -       rc = crypto_shash_final(md5, md5_hash);
> +       rc = crypto_shash_digest(md5, link_str, link_len, md5_hash);
>         if (rc)
>                 cifs_dbg(VFS, "%s: Could not generate md5 hash\n", __func__);
> -
> -symlink_hash_err:
>         cifs_free_hash(&md5);
>         return rc;
>  }
>
>  static int
>  parse_mf_symlink(const u8 *buf, unsigned int buf_len, unsigned int *_link_len,
>                  char **_link_str)
>  {
>         int rc;
>         unsigned int link_len;
>
> base-commit: 2af9b20dbb39f6ebf9b9b6c090271594627d818e
> --
> 2.42.0
>
Paulo Alcantara Oct. 31, 2023, 2:57 p.m. UTC | #2
Eric Biggers <ebiggers@kernel.org> writes:

> From: Eric Biggers <ebiggers@google.com>
>
> Simplify symlink_hash() by using crypto_shash_digest() instead of an
> init+update+final sequence.  This should also improve performance.
>
> Signed-off-by: Eric Biggers <ebiggers@google.com>
> ---
>  fs/smb/client/link.c | 16 ++--------------
>  1 file changed, 2 insertions(+), 14 deletions(-)
>
> diff --git a/fs/smb/client/link.c b/fs/smb/client/link.c
> index c66be4904e1f..a1da50e66fbb 100644
> --- a/fs/smb/client/link.c
> +++ b/fs/smb/client/link.c

Reviewed-by: Paulo Alcantara (SUSE) <pc@manguebit.com>
diff mbox series

Patch

diff --git a/fs/smb/client/link.c b/fs/smb/client/link.c
index c66be4904e1f..a1da50e66fbb 100644
--- a/fs/smb/client/link.c
+++ b/fs/smb/client/link.c
@@ -35,37 +35,25 @@ 
 #define CIFS_MF_SYMLINK_MD5_ARGS(md5_hash) md5_hash
 
 static int
 symlink_hash(unsigned int link_len, const char *link_str, u8 *md5_hash)
 {
 	int rc;
 	struct shash_desc *md5 = NULL;
 
 	rc = cifs_alloc_hash("md5", &md5);
 	if (rc)
-		goto symlink_hash_err;
+		return rc;
 
-	rc = crypto_shash_init(md5);
-	if (rc) {
-		cifs_dbg(VFS, "%s: Could not init md5 shash\n", __func__);
-		goto symlink_hash_err;
-	}
-	rc = crypto_shash_update(md5, link_str, link_len);
-	if (rc) {
-		cifs_dbg(VFS, "%s: Could not update with link_str\n", __func__);
-		goto symlink_hash_err;
-	}
-	rc = crypto_shash_final(md5, md5_hash);
+	rc = crypto_shash_digest(md5, link_str, link_len, md5_hash);
 	if (rc)
 		cifs_dbg(VFS, "%s: Could not generate md5 hash\n", __func__);
-
-symlink_hash_err:
 	cifs_free_hash(&md5);
 	return rc;
 }
 
 static int
 parse_mf_symlink(const u8 *buf, unsigned int buf_len, unsigned int *_link_len,
 		 char **_link_str)
 {
 	int rc;
 	unsigned int link_len;