crypto: caam - move DMA mask selection into a function
Exactly the same code to figure out DMA mask is repeated twice in the driver code. To avoid repetition, move that logic into a standalone subroutine in intern.h. While at it re-shuffle the code to make it more readable with early returns. Signed-off-by: Andrey Smirnov <andrew.smirnov@gmail.com> Reviewed-by: Horia Geantă <horia.geanta@nxp.com> Cc: Chris Spencer <christopher.spencer@sea.co.uk> Cc: Cory Tusar <cory.tusar@zii.aero> Cc: Chris Healy <cphealy@gmail.com> Cc: Lucas Stach <l.stach@pengutronix.de> Cc: Horia Geantă <horia.geanta@nxp.com> Cc: Aymen Sghaier <aymen.sghaier@nxp.com> Cc: Leonard Crestez <leonard.crestez@nxp.com> Cc: linux-crypto@vger.kernel.org Cc: linux-kernel@vger.kernel.org Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
This commit is contained in:
Родитель
671e50384e
Коммит
70c0cda27a
|
@ -711,16 +711,7 @@ static int caam_probe(struct platform_device *pdev)
|
||||||
JRSTART_JR1_START | JRSTART_JR2_START |
|
JRSTART_JR1_START | JRSTART_JR2_START |
|
||||||
JRSTART_JR3_START);
|
JRSTART_JR3_START);
|
||||||
|
|
||||||
if (sizeof(dma_addr_t) == sizeof(u64)) {
|
ret = dma_set_mask_and_coherent(dev, caam_get_dma_mask(dev));
|
||||||
if (caam_dpaa2)
|
|
||||||
ret = dma_set_mask_and_coherent(dev, DMA_BIT_MASK(49));
|
|
||||||
else if (of_device_is_compatible(nprop, "fsl,sec-v5.0"))
|
|
||||||
ret = dma_set_mask_and_coherent(dev, DMA_BIT_MASK(40));
|
|
||||||
else
|
|
||||||
ret = dma_set_mask_and_coherent(dev, DMA_BIT_MASK(36));
|
|
||||||
} else {
|
|
||||||
ret = dma_set_mask_and_coherent(dev, DMA_BIT_MASK(32));
|
|
||||||
}
|
|
||||||
if (ret) {
|
if (ret) {
|
||||||
dev_err(dev, "dma_set_mask_and_coherent failed (%d)\n", ret);
|
dev_err(dev, "dma_set_mask_and_coherent failed (%d)\n", ret);
|
||||||
goto disable_caam_emi_slow;
|
goto disable_caam_emi_slow;
|
||||||
|
|
|
@ -10,6 +10,8 @@
|
||||||
#ifndef INTERN_H
|
#ifndef INTERN_H
|
||||||
#define INTERN_H
|
#define INTERN_H
|
||||||
|
|
||||||
|
#include "ctrl.h"
|
||||||
|
|
||||||
/* Currently comes from Kconfig param as a ^2 (driver-required) */
|
/* Currently comes from Kconfig param as a ^2 (driver-required) */
|
||||||
#define JOBR_DEPTH (1 << CONFIG_CRYPTO_DEV_FSL_CAAM_RINGSIZE)
|
#define JOBR_DEPTH (1 << CONFIG_CRYPTO_DEV_FSL_CAAM_RINGSIZE)
|
||||||
|
|
||||||
|
@ -215,4 +217,22 @@ DEFINE_SIMPLE_ATTRIBUTE(caam_fops_u32_ro, caam_debugfs_u32_get, NULL, "%llu\n");
|
||||||
DEFINE_SIMPLE_ATTRIBUTE(caam_fops_u64_ro, caam_debugfs_u64_get, NULL, "%llu\n");
|
DEFINE_SIMPLE_ATTRIBUTE(caam_fops_u64_ro, caam_debugfs_u64_get, NULL, "%llu\n");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
static inline u64 caam_get_dma_mask(struct device *dev)
|
||||||
|
{
|
||||||
|
struct device_node *nprop = dev->of_node;
|
||||||
|
|
||||||
|
if (sizeof(dma_addr_t) != sizeof(u64))
|
||||||
|
return DMA_BIT_MASK(32);
|
||||||
|
|
||||||
|
if (caam_dpaa2)
|
||||||
|
return DMA_BIT_MASK(49);
|
||||||
|
|
||||||
|
if (of_device_is_compatible(nprop, "fsl,sec-v5.0-job-ring") ||
|
||||||
|
of_device_is_compatible(nprop, "fsl,sec-v5.0"))
|
||||||
|
return DMA_BIT_MASK(40);
|
||||||
|
|
||||||
|
return DMA_BIT_MASK(36);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif /* INTERN_H */
|
#endif /* INTERN_H */
|
||||||
|
|
|
@ -543,20 +543,7 @@ static int caam_jr_probe(struct platform_device *pdev)
|
||||||
|
|
||||||
jrpriv->rregs = (struct caam_job_ring __iomem __force *)ctrl;
|
jrpriv->rregs = (struct caam_job_ring __iomem __force *)ctrl;
|
||||||
|
|
||||||
if (sizeof(dma_addr_t) == sizeof(u64)) {
|
error = dma_set_mask_and_coherent(jrdev, caam_get_dma_mask(jrdev));
|
||||||
if (caam_dpaa2)
|
|
||||||
error = dma_set_mask_and_coherent(jrdev,
|
|
||||||
DMA_BIT_MASK(49));
|
|
||||||
else if (of_device_is_compatible(nprop,
|
|
||||||
"fsl,sec-v5.0-job-ring"))
|
|
||||||
error = dma_set_mask_and_coherent(jrdev,
|
|
||||||
DMA_BIT_MASK(40));
|
|
||||||
else
|
|
||||||
error = dma_set_mask_and_coherent(jrdev,
|
|
||||||
DMA_BIT_MASK(36));
|
|
||||||
} else {
|
|
||||||
error = dma_set_mask_and_coherent(jrdev, DMA_BIT_MASK(32));
|
|
||||||
}
|
|
||||||
if (error) {
|
if (error) {
|
||||||
dev_err(jrdev, "dma_set_mask_and_coherent failed (%d)\n",
|
dev_err(jrdev, "dma_set_mask_and_coherent failed (%d)\n",
|
||||||
error);
|
error);
|
||||||
|
|
Загрузка…
Ссылка в новой задаче