crypto: sahara - add support for i.MX53
authorSteffen Trumtrar <s.trumtrar@pengutronix.de>
Mon, 1 Dec 2014 12:26:32 +0000 (13:26 +0100)
committerHerbert Xu <herbert@gondor.apana.org.au>
Wed, 3 Dec 2014 14:30:18 +0000 (22:30 +0800)
The Sahara on the i.MX53 is of version 4. Add support for probing the
device.

Signed-off-by: Steffen Trumtrar <s.trumtrar@pengutronix.de>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Documentation/devicetree/bindings/crypto/fsl-imx-sahara.txt
drivers/crypto/sahara.c

index 5c65eccd0e56b3a58b611bac9da4b6f9f40a52d8..e8a35c71e9478c76db058ac1c6cf6c921bc919ad 100644 (file)
@@ -1,5 +1,5 @@
 Freescale SAHARA Cryptographic Accelerator included in some i.MX chips.
-Currently only i.MX27 is supported.
+Currently only i.MX27 and i.MX53 are supported.
 
 Required properties:
 - compatible : Should be "fsl,<soc>-sahara"
index 6fb16fe7eea55433d6fa8bbfa69575f477902b62..55c0d2bea42684600501d0185309fa812307fcbf 100644 (file)
 #include <linux/kernel.h>
 #include <linux/module.h>
 #include <linux/of.h>
+#include <linux/of_device.h>
 #include <linux/platform_device.h>
 
 #define SAHARA_NAME "sahara"
 #define SAHARA_VERSION_3       3
+#define SAHARA_VERSION_4       4
 #define SAHARA_TIMEOUT_MS      1000
 #define SAHARA_MAX_HW_DESC     2
 #define SAHARA_MAX_HW_LINK     20
@@ -130,6 +132,7 @@ struct sahara_aes_reqctx {
 
 struct sahara_dev {
        struct device           *device;
+       unsigned int            version;
        void __iomem            *regs_base;
        struct clk              *clk_ipg;
        struct clk              *clk_ahb;
@@ -860,6 +863,7 @@ static struct platform_device_id sahara_platform_ids[] = {
 MODULE_DEVICE_TABLE(platform, sahara_platform_ids);
 
 static struct of_device_id sahara_dt_ids[] = {
+       { .compatible = "fsl,imx53-sahara" },
        { .compatible = "fsl,imx27-sahara" },
        { /* sentinel */ }
 };
@@ -973,13 +977,23 @@ static int sahara_probe(struct platform_device *pdev)
        clk_prepare_enable(dev->clk_ahb);
 
        version = sahara_read(dev, SAHARA_REG_VERSION);
-       if (version != SAHARA_VERSION_3) {
+       if (of_device_is_compatible(pdev->dev.of_node, "fsl,imx27-sahara")) {
+               if (version != SAHARA_VERSION_3)
+                       err = -ENODEV;
+       } else if (of_device_is_compatible(pdev->dev.of_node,
+                       "fsl,imx53-sahara")) {
+               if (((version >> 8) & 0xff) != SAHARA_VERSION_4)
+                       err = -ENODEV;
+               version = (version >> 8) & 0xff;
+       }
+       if (err == -ENODEV) {
                dev_err(&pdev->dev, "SAHARA version %d not supported\n",
-                       version);
-               err = -ENODEV;
+                               version);
                goto err_algs;
        }
 
+       dev->version = version;
+
        sahara_write(dev, SAHARA_CMD_RESET | SAHARA_CMD_MODE_BATCH,
                     SAHARA_REG_CMD);
        sahara_write(dev, SAHARA_CONTROL_SET_THROTTLE(0) |