diff options
| author | Thomas Petazzoni <[email protected]> | 2015-09-18 17:25:36 +0200 | 
|---|---|---|
| committer | Herbert Xu <[email protected]> | 2015-09-21 22:57:36 +0800 | 
| commit | cfcd2271a9076a9891014bc8e18d4fd48acccffe (patch) | |
| tree | ea6f3f654525f9d2f4c434576626010cb0e98106 /scripts/basic/fixdep.c | |
| parent | 84cba178a3b88efe2668a9039f70abda072faa21 (diff) | |
crypto: marvell - properly handle CRYPTO_TFM_REQ_MAY_BACKLOG-flagged requests
The mv_cesa_queue_req() function calls crypto_enqueue_request() to
enqueue a request. In the normal case (i.e the queue isn't full), this
function returns -EINPROGRESS. The current Marvell CESA crypto driver
takes this into account and cleans up the request only if an error
occured, i.e if the return value is not -EINPROGRESS.
Unfortunately this causes problems with
CRYPTO_TFM_REQ_MAY_BACKLOG-flagged requests. When such a request is
passed to crypto_enqueue_request() and the queue is full,
crypto_enqueue_request() will return -EBUSY, but will keep the request
enqueued nonetheless. This situation was not properly handled by the
Marvell CESA driver, which was anyway cleaning up the request in such
a situation. When later on the request was taken out of the backlog
and actually processed, a kernel crash occured due to the internal
driver data structures for this structure having been cleaned up.
To avoid this situation, this commit adds a
mv_cesa_req_needs_cleanup() helper function which indicates if the
request needs to be cleaned up or not after a call to
crypto_enqueue_request(). This helper allows to do the cleanup only in
the appropriate cases, and all call sites of mv_cesa_queue_req() are
fixed to use this new helper function.
Reported-by: Vincent Donnefort <[email protected]>
Fixes: db509a45339fd ("crypto: marvell/cesa - add TDMA support")
Cc: <[email protected]> # v4.2+
Signed-off-by: Thomas Petazzoni <[email protected]>
Acked-by: Boris Brezillon <[email protected]>
Tested-by: Vincent Donnefort <[email protected]>
Signed-off-by: Herbert Xu <[email protected]>
Diffstat (limited to 'scripts/basic/fixdep.c')
0 files changed, 0 insertions, 0 deletions