crypto: inside-secure - do not process request if no command was issued
authorAntoine Tenart <antoine.tenart@bootlin.com>
Tue, 13 Feb 2018 08:26:54 +0000 (09:26 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 25 May 2018 14:17:45 +0000 (16:17 +0200)
[ Upstream commit 95831ceafc0de7d94a5fe86ebb1c2042317cc2cd ]

This patch adds a check in the SafeXcel dequeue function, to avoid
processing request further if no hardware command was issued. This can
happen in certain cases where the ->send() function caches all the data
that would have been send.

Fixes: 809778e02cd4 ("crypto: inside-secure - fix hash when length is a multiple of a block")
Signed-off-by: Antoine Tenart <antoine.tenart@bootlin.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: Sasha Levin <alexander.levin@microsoft.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/crypto/inside-secure/safexcel.c

index d4c81cb73bee6ccfdbea9a67af7237cea86649d2..3ee68ecde9ec1bf14cefd6f492ce483d38955832 100644 (file)
@@ -462,6 +462,15 @@ void safexcel_dequeue(struct safexcel_crypto_priv *priv, int ring)
                if (backlog)
                        backlog->complete(backlog, -EINPROGRESS);
 
+               /* In case the send() helper did not issue any command to push
+                * to the engine because the input data was cached, continue to
+                * dequeue other requests as this is valid and not an error.
+                */
+               if (!commands && !results) {
+                       kfree(request);
+                       continue;
+               }
+
                spin_lock_bh(&priv->ring[ring].egress_lock);
                list_add_tail(&request->list, &priv->ring[ring].list);
                spin_unlock_bh(&priv->ring[ring].egress_lock);