Commit 6150f3bc authored by Nicolas Royer's avatar Nicolas Royer Committed by Herbert Xu

ARM: AT91SAM9G45: same platform data structure for all crypto peripherals

Only AES use DMA in AT91SAM9G45 (TDES and SHA use PDC).

However latest Atmel TDES and SHA IP releases use DMA instead of PDC.
  --> Atmel TDES and SHA drivers need DMA platform data for those IP releases.

Goal of this patch is to use the same platform data structure for all Atmel
crypto peripherals. This structure contains information about DMA interface.
Signed-off-by: default avatarNicolas Royer <nicolas@eukrea.com>
Acked-by: default avatarNicolas Ferre <nicolas.ferre@atmel.com>
Acked-by: default avatarEric Bénard <eric@eukrea.com>
Tested-by: default avatarEric Bénard <eric@eukrea.com>
Signed-off-by: default avatarHerbert Xu <herbert@gondor.apana.org.au>
parent ca81a1a1
...@@ -18,7 +18,7 @@ ...@@ -18,7 +18,7 @@
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/i2c-gpio.h> #include <linux/i2c-gpio.h>
#include <linux/atmel-mci.h> #include <linux/atmel-mci.h>
#include <linux/platform_data/atmel-aes.h> #include <linux/platform_data/crypto-atmel.h>
#include <linux/platform_data/at91_adc.h> #include <linux/platform_data/at91_adc.h>
...@@ -1900,7 +1900,8 @@ static void __init at91_add_device_tdes(void) {} ...@@ -1900,7 +1900,8 @@ static void __init at91_add_device_tdes(void) {}
* -------------------------------------------------------------------- */ * -------------------------------------------------------------------- */
#if defined(CONFIG_CRYPTO_DEV_ATMEL_AES) || defined(CONFIG_CRYPTO_DEV_ATMEL_AES_MODULE) #if defined(CONFIG_CRYPTO_DEV_ATMEL_AES) || defined(CONFIG_CRYPTO_DEV_ATMEL_AES_MODULE)
static struct aes_platform_data aes_data; static struct crypto_platform_data aes_data;
static struct crypto_dma_data alt_atslave;
static u64 aes_dmamask = DMA_BIT_MASK(32); static u64 aes_dmamask = DMA_BIT_MASK(32);
static struct resource aes_resources[] = { static struct resource aes_resources[] = {
...@@ -1931,23 +1932,20 @@ static struct platform_device at91sam9g45_aes_device = { ...@@ -1931,23 +1932,20 @@ static struct platform_device at91sam9g45_aes_device = {
static void __init at91_add_device_aes(void) static void __init at91_add_device_aes(void)
{ {
struct at_dma_slave *atslave; struct at_dma_slave *atslave;
struct aes_dma_data *alt_atslave;
alt_atslave = kzalloc(sizeof(struct aes_dma_data), GFP_KERNEL);
/* DMA TX slave channel configuration */ /* DMA TX slave channel configuration */
atslave = &alt_atslave->txdata; atslave = &alt_atslave.txdata;
atslave->dma_dev = &at_hdmac_device.dev; atslave->dma_dev = &at_hdmac_device.dev;
atslave->cfg = ATC_FIFOCFG_ENOUGHSPACE | ATC_SRC_H2SEL_HW | atslave->cfg = ATC_FIFOCFG_ENOUGHSPACE | ATC_SRC_H2SEL_HW |
ATC_SRC_PER(AT_DMA_ID_AES_RX); ATC_SRC_PER(AT_DMA_ID_AES_RX);
/* DMA RX slave channel configuration */ /* DMA RX slave channel configuration */
atslave = &alt_atslave->rxdata; atslave = &alt_atslave.rxdata;
atslave->dma_dev = &at_hdmac_device.dev; atslave->dma_dev = &at_hdmac_device.dev;
atslave->cfg = ATC_FIFOCFG_ENOUGHSPACE | ATC_DST_H2SEL_HW | atslave->cfg = ATC_FIFOCFG_ENOUGHSPACE | ATC_DST_H2SEL_HW |
ATC_DST_PER(AT_DMA_ID_AES_TX); ATC_DST_PER(AT_DMA_ID_AES_TX);
aes_data.dma_slave = alt_atslave; aes_data.dma_slave = &alt_atslave;
platform_device_register(&at91sam9g45_aes_device); platform_device_register(&at91sam9g45_aes_device);
} }
#else #else
......
#ifndef __LINUX_ATMEL_AES_H #ifndef __LINUX_CRYPTO_ATMEL_H
#define __LINUX_ATMEL_AES_H #define __LINUX_CRYPTO_ATMEL_H
#include <linux/platform_data/dma-atmel.h> #include <linux/platform_data/dma-atmel.h>
/** /**
* struct aes_dma_data - DMA data for AES * struct crypto_dma_data - DMA data for AES/TDES/SHA
*/ */
struct aes_dma_data { struct crypto_dma_data {
struct at_dma_slave txdata; struct at_dma_slave txdata;
struct at_dma_slave rxdata; struct at_dma_slave rxdata;
}; };
/** /**
* struct aes_platform_data - board-specific AES configuration * struct crypto_platform_data - board-specific AES/TDES/SHA configuration
* @dma_slave: DMA slave interface to use in data transfers. * @dma_slave: DMA slave interface to use in data transfers.
*/ */
struct aes_platform_data { struct crypto_platform_data {
struct aes_dma_data *dma_slave; struct crypto_dma_data *dma_slave;
}; };
#endif /* __LINUX_ATMEL_AES_H */ #endif /* __LINUX_CRYPTO_ATMEL_H */
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment