]> git.hungrycats.org Git - linux/commitdiff
crypto: marvell - Update transformation context for each dequeued req
authorRomain Perier <romain.perier@free-electrons.com>
Tue, 9 Aug 2016 09:03:18 +0000 (11:03 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 31 Oct 2016 11:02:09 +0000 (05:02 -0600)
commit 09951d83fc58a6f772de09c08e370f6d9970dbb6 upstream.

So far, sub part of mv_cesa_int was responsible of dequeuing complete
requests, then call the 'cleanup' operation on these reqs and call the
crypto api callback 'complete'. The problem is that the transformation
context 'ctx' is retrieved only once before the while loop. Which means
that the wrong 'cleanup' operation might be called on the wrong type of
cesa requests, it can lead to memory corruptions with this message:

marvell-cesa f1090000.crypto: dma_pool_free cesa_padding, 5a5a5a5a/5a5a5a5a (bad dma)

This commit fixes the issue, by updating the transformation context for
each dequeued cesa request.

Fixes: commit 85030c5168f1 ("crypto: marvell - Add support for chai...")
Signed-off-by: Romain Perier <romain.perier@free-electrons.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/crypto/marvell/cesa.c

index d64af8625d7e3e8525b691f6b0f5be59cc19e705..37dadb2a4feb459743e44c7066beef99f6fb973e 100644 (file)
@@ -166,6 +166,7 @@ static irqreturn_t mv_cesa_int(int irq, void *priv)
                        if (!req)
                                break;
 
+                       ctx = crypto_tfm_ctx(req->tfm);
                        mv_cesa_complete_req(ctx, req, 0);
                }
        }