]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
crypto: crypto4xx - Fix size used in dma_free_coherent()
authorChristophe Jaillet <christophe.jaillet@wanadoo.fr>
Fri, 7 Oct 2016 20:36:20 +0000 (22:36 +0200)
committerHerbert Xu <herbert@gondor.apana.org.au>
Fri, 21 Oct 2016 03:03:41 +0000 (11:03 +0800)
The size used in 'dma_free_coherent()' looks un-initialized here.
ctx->sa_len is set a few lines below and is apparently not set by the
caller.
So use 'size' as in the corresponding 'dma_alloc_coherent()' a few lines
above.

This has been spotted with coccinelle, using the following script:
////////////////////
@r@
expression x0, x1, y0, y1, z0, z1, t0, t1, ret;
@@

*   ret = dma_alloc_coherent(x0, y0, z0, t0);
    ...
*   dma_free_coherent(x1, y1, ret, t1);

@script:python@
y0 << r.y0;
y1 << r.y1;

@@
if y1.find(y0) == -1:
 print "WARNING: sizes look different:  '%s'   vs   '%s'" % (y0, y1)
////////////////////

Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
drivers/crypto/amcc/crypto4xx_core.c

index dae1e39139e9a19bb0155f42d5ccf233d6c15dd4..d10b4ae5e0da8526e3f722add49989148ff10199 100644 (file)
@@ -135,8 +135,7 @@ int crypto4xx_alloc_sa(struct crypto4xx_ctx *ctx, u32 size)
        ctx->sa_out = dma_alloc_coherent(ctx->dev->core_dev->device, size * 4,
                                         &ctx->sa_out_dma_addr, GFP_ATOMIC);
        if (ctx->sa_out == NULL) {
-               dma_free_coherent(ctx->dev->core_dev->device,
-                                 ctx->sa_len * 4,
+               dma_free_coherent(ctx->dev->core_dev->device, size * 4,
                                  ctx->sa_in, ctx->sa_in_dma_addr);
                return -ENOMEM;
        }