usb: renesas_usbhs: Add support for RZ/A2
authorChris Brandt <chris.brandt@renesas.com>
Wed, 15 May 2019 15:20:44 +0000 (10:20 -0500)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 21 May 2019 08:25:59 +0000 (10:25 +0200)
The RZ/A2 is similar to the R-Car Gen3 with some small differences.

Signed-off-by: Chris Brandt <chris.brandt@renesas.com>
Reviewed-by: Simon Horman <horms+renesas@verge.net.au>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/usb/renesas_usbhs/Makefile
drivers/usb/renesas_usbhs/common.c
drivers/usb/renesas_usbhs/rza.h
drivers/usb/renesas_usbhs/rza2.c [new file with mode: 0644]
include/linux/usb/renesas_usbhs.h

index 5c5b51bb48efefa778a71b5ee1f0ad82a3bd91fa..a1fed56b0957991306dba0ee8d066d43493d67aa 100644 (file)
@@ -5,7 +5,7 @@
 
 obj-$(CONFIG_USB_RENESAS_USBHS)        += renesas_usbhs.o
 
-renesas_usbhs-y                        := common.o mod.o pipe.o fifo.o rcar2.o rcar3.o rza.o
+renesas_usbhs-y                        := common.o mod.o pipe.o fifo.o rcar2.o rcar3.o rza.o rza2.o
 
 ifneq ($(CONFIG_USB_RENESAS_USBHS_HCD),)
        renesas_usbhs-y         += mod_host.o
index 734fb4e542c5b3bd7ed40b9d129303ad9a7101fb..c7c9c5d75a5678e275aaafab5b7bff40e8195887 100644 (file)
@@ -571,6 +571,17 @@ static const struct usbhs_of_data rza1_data = {
        }
 };
 
+static const struct usbhs_of_data rza2_data = {
+       .platform_callback = &usbhs_rza2_ops,
+       .param = {
+               .type = USBHS_TYPE_RZA2,
+               .has_cnen = 1,
+               .cfifo_byte_addr = 1,
+               .pipe_configs = usbhsc_new_pipe,
+               .pipe_size = ARRAY_SIZE(usbhsc_new_pipe),
+       }
+};
+
 /*
  *             platform functions
  */
@@ -619,6 +630,10 @@ static const struct of_device_id usbhs_of_match[] = {
                .compatible = "renesas,rza1-usbhs",
                .data = &rza1_data,
        },
+       {
+               .compatible = "renesas,rza2-usbhs",
+               .data = &rza2_data,
+       },
        { },
 };
 MODULE_DEVICE_TABLE(of, usbhs_of_match);
index ca917ca54f6d2893a35d894c8f1580490f78e0c0..073a53d1d442bd0e0908e704abdea56d54f35b2b 100644 (file)
@@ -2,3 +2,4 @@
 #include "common.h"
 
 extern const struct renesas_usbhs_platform_callback usbhs_rza1_ops;
+extern const struct renesas_usbhs_platform_callback usbhs_rza2_ops;
diff --git a/drivers/usb/renesas_usbhs/rza2.c b/drivers/usb/renesas_usbhs/rza2.c
new file mode 100644 (file)
index 0000000..9d8551f
--- /dev/null
@@ -0,0 +1,72 @@
+// SPDX-License-Identifier: GPL-2.0
+/*
+ * Renesas USB driver RZ/A2 initialization and power control
+ *
+ * Copyright (C) 2019 Chris Brandt
+ * Copyright (C) 2019 Renesas Electronics Corporation
+ */
+
+#include <linux/delay.h>
+#include <linux/io.h>
+#include <linux/of_device.h>
+#include <linux/phy/phy.h>
+#include "common.h"
+#include "rza.h"
+
+static int usbhs_rza2_hardware_init(struct platform_device *pdev)
+{
+       struct usbhs_priv *priv = usbhs_pdev_to_priv(pdev);
+       struct phy *phy = phy_get(&pdev->dev, "usb");
+
+       if (IS_ERR(phy))
+               return PTR_ERR(phy);
+
+       priv->phy = phy;
+       return 0;
+}
+
+static int usbhs_rza2_hardware_exit(struct platform_device *pdev)
+{
+       struct usbhs_priv *priv = usbhs_pdev_to_priv(pdev);
+
+       phy_put(priv->phy);
+       priv->phy = NULL;
+
+       return 0;
+}
+
+static int usbhs_rza2_power_ctrl(struct platform_device *pdev,
+                               void __iomem *base, int enable)
+{
+       struct usbhs_priv *priv = usbhs_pdev_to_priv(pdev);
+       int retval = 0;
+
+       if (!priv->phy)
+               return -ENODEV;
+
+       if (enable) {
+               retval = phy_init(priv->phy);
+               usbhs_bset(priv, SUSPMODE, SUSPM, SUSPM);
+               udelay(100);    /* Wait for PLL to become stable */
+               if (!retval)
+                       retval = phy_power_on(priv->phy);
+       } else {
+               usbhs_bset(priv, SUSPMODE, SUSPM, 0);
+               phy_power_off(priv->phy);
+               phy_exit(priv->phy);
+       }
+
+       return retval;
+}
+
+static int usbhs_rza2_get_id(struct platform_device *pdev)
+{
+       return USBHS_GADGET;
+}
+
+const struct renesas_usbhs_platform_callback usbhs_rza2_ops = {
+       .hardware_init = usbhs_rza2_hardware_init,
+       .hardware_exit = usbhs_rza2_hardware_exit,
+       .power_ctrl = usbhs_rza2_power_ctrl,
+       .get_id = usbhs_rza2_get_id,
+};
index 87043fd21d54c3b0b03ac9cf9621e45c65483531..3f53043fb56b534a735dd8c14f8c167843d65c96 100644 (file)
@@ -199,6 +199,7 @@ struct renesas_usbhs_driver_param {
 #define USBHS_TYPE_RCAR_GEN3           2
 #define USBHS_TYPE_RCAR_GEN3_WITH_PLL  3
 #define USBHS_TYPE_RZA1                        4
+#define USBHS_TYPE_RZA2                        5
 
 /*
  * option: