aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlex Porosanu <alexandru.porosanu@nxp.com>2016-11-09 03:46:11 -0500
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2017-01-06 04:40:13 -0500
commit21cc91554c3da12708c9a85a98ce144409dc21ef (patch)
tree444256ba31bbe9b5120d30f44b857f69a10382e0
parente71b4e061c9677cef1f1f38fd7236e198fab1287 (diff)
crypto: caam - fix AEAD givenc descriptors
commit d128af17876d79b87edf048303f98b35f6a53dbc upstream. The AEAD givenc descriptor relies on moving the IV through the output FIFO and then back to the CTX2 for authentication. The SEQ FIFO STORE could be scheduled before the data can be read from OFIFO, especially since the SEQ FIFO LOAD needs to wait for the SEQ FIFO LOAD SKIP to finish first. The SKIP takes more time when the input is SG than when it's a contiguous buffer. If the SEQ FIFO LOAD is not scheduled before the STORE, the DECO will hang waiting for data to be available in the OFIFO so it can be transferred to C2. In order to overcome this, first force transfer of IV to C2 by starting the "cryptlen" transfer first and then starting to store data from OFIFO to the output buffer. Fixes: 1acebad3d8db8 ("crypto: caam - faster aead implementation") Signed-off-by: Alex Porosanu <alexandru.porosanu@nxp.com> Signed-off-by: Horia Geantă <horia.geanta@nxp.com> Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-rw-r--r--drivers/crypto/caam/caamalg.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/drivers/crypto/caam/caamalg.c b/drivers/crypto/caam/caamalg.c
index 954a64c7757b..c310318b34dd 100644
--- a/drivers/crypto/caam/caamalg.c
+++ b/drivers/crypto/caam/caamalg.c
@@ -736,7 +736,9 @@ copy_iv:
736 736
737 /* Will read cryptlen */ 737 /* Will read cryptlen */
738 append_math_add(desc, VARSEQINLEN, SEQINLEN, REG0, CAAM_CMD_SZ); 738 append_math_add(desc, VARSEQINLEN, SEQINLEN, REG0, CAAM_CMD_SZ);
739 aead_append_src_dst(desc, FIFOLD_TYPE_MSG1OUT2); 739 append_seq_fifo_load(desc, 0, FIFOLD_CLASS_BOTH | KEY_VLF |
740 FIFOLD_TYPE_MSG1OUT2 | FIFOLD_TYPE_LASTBOTH);
741 append_seq_fifo_store(desc, 0, FIFOST_TYPE_MESSAGE_DATA | KEY_VLF);
740 742
741 /* Write ICV */ 743 /* Write ICV */
742 append_seq_store(desc, ctx->authsize, LDST_CLASS_2_CCB | 744 append_seq_store(desc, ctx->authsize, LDST_CLASS_2_CCB |