summaryrefslogtreecommitdiffstats
path: root/crypto/ccm.c
diff options
context:
space:
mode:
authorHoria Geantă <horia.geanta@nxp.com>2017-02-10 14:07:25 +0200
committerHerbert Xu <herbert@gondor.apana.org.au>2017-02-15 13:23:43 +0800
commit944c3d4dca34403e802287a1e7e9d02c06dce0d5 (patch)
treefb737fa746ba06a2a709a91d6de57c5e768074ff /crypto/ccm.c
parent0355d23d4034f42b28db19520bc8865e26053404 (diff)
downloadlinux-944c3d4dca34403e802287a1e7e9d02c06dce0d5.tar.gz
linux-944c3d4dca34403e802287a1e7e9d02c06dce0d5.tar.bz2
linux-944c3d4dca34403e802287a1e7e9d02c06dce0d5.zip
crypto: caam - fix state buffer DMA (un)mapping
If we register the DMA API debug notification chain to receive platform bus events: dma_debug_add_bus(&platform_bus_type); we start receiving warnings after a simple test like "modprobe caam_jr && modprobe caamhash && modprobe -r caamhash && modprobe -r caam_jr": platform ffe301000.jr: DMA-API: device driver has pending DMA allocations while released from device [count=1938] One of leaked entries details: [device address=0x0000000173fda090] [size=63 bytes] [mapped with DMA_TO_DEVICE] [mapped as single] It turns out there are several issues with handling buf_dma (mapping of buffer holding the previous chunk smaller than hash block size): -detection of buf_dma mapping failure occurs too late, after a job descriptor using that value has been submitted for execution -dma mapping leak - unmapping is not performed in all places: for e.g. in ahash_export or in most ahash_fin* callbacks (due to current back-to-back implementation of buf_dma unmapping/mapping) Fix these by: -calling dma_mapping_error() on buf_dma right after the mapping and providing an error code if needed -unmapping buf_dma during the "job done" (ahash_done_*) callbacks Signed-off-by: Horia Geantă <horia.geanta@nxp.com> Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Diffstat (limited to 'crypto/ccm.c')
0 files changed, 0 insertions, 0 deletions