On Thu, Nov 04, 2010 at 01:43:16PM -0400, Miloslav Trmac wrote:
>
> shash_async_import() - it assumes that the struct shash_desc placed in 
> ahash_request_ctx() of the struct ahash_request was initialized to point to 
> the tfm, which is only done in shash_async_init().

Thanks for catching this.  This patch should fix the problem.

commit 8850e3641dcc7446628681bd7c5f771005e0b208
Author: Herbert Xu <herb...@gondor.apana.org.au>
Date:   Thu Nov 4 13:00:22 2010 -0500

    crypto: hash - Fix async import on shash algorithm
    
    The function shash_async_import did not initialise the descriptor
    correctly prior to calling the underlying shash import function.
    
    This patch adds the required initialisation.
    
    Reported-by: Miloslav Trmac <m...@redhat.com>
    Signed-off-by: Herbert Xu <herb...@gondor.apana.org.au>

diff --git a/crypto/shash.c b/crypto/shash.c
index 22fd943..76f74b9 100644
--- a/crypto/shash.c
+++ b/crypto/shash.c
@@ -310,7 +310,13 @@ static int shash_async_export(struct ahash_request *req, 
void *out)
 
 static int shash_async_import(struct ahash_request *req, const void *in)
 {
-       return crypto_shash_import(ahash_request_ctx(req), in);
+       struct crypto_shash **ctx = crypto_ahash_ctx(crypto_ahash_reqtfm(req));
+       struct shash_desc *desc = ahash_request_ctx(req);
+
+       desc->tfm = *ctx;
+       desc->flags = req->base.flags;
+
+       return crypto_shash_import(desc, in);
 }
 
 static void crypto_exit_shash_ops_async(struct crypto_tfm *tfm)

Cheers,
-- 
Email: Herbert Xu <herb...@gondor.apana.org.au>
Home Page: http://gondor.apana.org.au/~herbert/
PGP Key: http://gondor.apana.org.au/~herbert/pubkey.txt
--
To unsubscribe from this list: send the line "unsubscribe linux-crypto" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to