On 8/29/24 3:30 AM, Minda Chen wrote:
Add cdns USB3 wrapper driver.

Signed-off-by: Minda Chen <minda.c...@starfivetech.com>
---
  drivers/usb/cdns3/Kconfig          |   7 ++
  drivers/usb/cdns3/Makefile         |   2 +
  drivers/usb/cdns3/cdns3-starfive.c | 191 +++++++++++++++++++++++++++++
  3 files changed, 200 insertions(+)
  create mode 100644 drivers/usb/cdns3/cdns3-starfive.c

diff --git a/drivers/usb/cdns3/Kconfig b/drivers/usb/cdns3/Kconfig
index 35b61497d9..f8f363982b 100644
--- a/drivers/usb/cdns3/Kconfig
+++ b/drivers/usb/cdns3/Kconfig
@@ -55,4 +55,11 @@ config USB_CDNS3_TI
        help
          Say 'Y' here if you are building for Texas Instruments
          platforms that contain Cadence USB3 controller core. E.g.: J721e.
+
+config USB_CDNS3_STARFIVE
+       tristate "Cadence USB3 support on Starfive platforms"
+       default USB_CDNS3

Should this be 'default y if SOMEPLATFORM' ?

[...]

+static void cdns_mode_init(struct cdns_starfive *data, enum usb_dr_mode mode)
+{
+       unsigned int strap, suspendm;
+
+       regmap_update_bits(data->stg_syscon, data->stg_usb_mode,
+                          USB_MISC_CFG_MASK,
+                          USB_SUSPENDM_BYPS | USB_PLL_EN | USB_REFCLK_MODE);
+
+       switch (mode) {
+       case USB_DR_MODE_HOST:
+               strap = USB_STRAP_HOST;
+               suspendm = USB_SUSPENDM_HOST;
+               break;
+
+       case USB_DR_MODE_PERIPHERAL:
+               strap = USB_STRAP_DEVICE;
+               suspendm = 0;
+               break;
+       default:
+               return;
+       }
+
+       regmap_update_bits(data->stg_syscon, data->stg_usb_mode,
+                          USB_STRAP_MASK, strap);
+       regmap_update_bits(data->stg_syscon, data->stg_usb_mode,
+                          USB_SUSPENDM_MASK, suspendm);

Are two consecutive writes to the same register mandatory here ?

+}

[...]

+static int cdns_starfive_probe(struct udevice *dev)
+{
+       struct cdns_starfive *data = dev_get_plat(dev);
+       enum usb_dr_mode dr_mode;
+       ofnode node;
+       int ret;
+
+       data->dev = dev;
+
+       ret = cdns_starfive_get_syscon(data);
+       if (ret)
+               return ret;
+
+       node = ofnode_by_compatible(dev_ofnode(dev), "cdns,usb3");
+       if (!ofnode_valid(node)) {
+               dev_err(dev, "failed to get usb node\n");

USB in capitals.

+               return -ENODEV;
+       }
+
+       dr_mode = usb_get_dr_mode(node);
+
+       data->mode = dr_mode;
+       ret = cdns_clk_rst_init(data);
+       if (ret) {
+               dev_err(data->dev, "clk reset failed: %d\n", ret);
+               return ret;
+       }
+       cdns_mode_init(data, dr_mode);
+
+       return 0;
+}

Looks pretty good, thanks .

Reply via email to