Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

crypto: atmel-sha - correct the max burst size

The maximum source and destination burst size is 16
according to the datasheet of Atmel DMA. And the value
is also checked in function at_xdmac_csize of Atmel
DMA driver. With the restrict, the value beyond maximum
value will not be processed in DMA driver, so SHA384 and
SHA512 will not work and the program will wait forever.

So here change the max burst size of all the cases to 16
in order to make SHA384 and SHA512 work and keep consistent
with DMA driver and datasheet.

Signed-off-by: Leilei Zhao <leilei.zhao@atmel.com>
Acked-by: Nicolas Ferre <nicolas.ferre@atmel.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>

authored by

Leilei Zhao and committed by
Herbert Xu
3f1992c0 62728e82

+2 -8
+2 -8
drivers/crypto/atmel-sha.c
··· 432 432 dev_dbg(dd->dev, "xmit_dma: digcnt: 0x%llx 0x%llx, length: %d, final: %d\n", 433 433 ctx->digcnt[1], ctx->digcnt[0], length1, final); 434 434 435 - if (ctx->flags & (SHA_FLAGS_SHA1 | SHA_FLAGS_SHA224 | 436 - SHA_FLAGS_SHA256)) { 437 - dd->dma_lch_in.dma_conf.src_maxburst = 16; 438 - dd->dma_lch_in.dma_conf.dst_maxburst = 16; 439 - } else { 440 - dd->dma_lch_in.dma_conf.src_maxburst = 32; 441 - dd->dma_lch_in.dma_conf.dst_maxburst = 32; 442 - } 435 + dd->dma_lch_in.dma_conf.src_maxburst = 16; 436 + dd->dma_lch_in.dma_conf.dst_maxburst = 16; 443 437 444 438 dmaengine_slave_config(dd->dma_lch_in.chan, &dd->dma_lch_in.dma_conf); 445 439