]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
phy: tegra: xusb: Parse dual-role mode property
authorThierry Reding <treding@nvidia.com>
Thu, 21 Feb 2019 15:46:32 +0000 (16:46 +0100)
committerKishon Vijay Abraham I <kishon@ti.com>
Wed, 17 Apr 2019 08:42:43 +0000 (14:12 +0530)
The device tree bindings document the "mode" property of "ports"
subnodes, but the driver was not parsing the property. In preparation
for adding role switching, parse the property at probe time.

Based on work by JC Kuo <jckuo@nvidia.com>.

Reviewed-by: JC Kuo <jckuo@nvidia.com>
Signed-off-by: Thierry Reding <treding@nvidia.com>
Signed-off-by: Kishon Vijay Abraham I <kishon@ti.com>
drivers/phy/tegra/xusb.c
drivers/phy/tegra/xusb.h

index e3bc60cfe6a194fc3070db9e94c243f5850c0c53..57a2d08ef6daca315b20db625b9c0354367e1980 100644 (file)
@@ -546,13 +546,34 @@ static void tegra_xusb_port_unregister(struct tegra_xusb_port *port)
        device_unregister(&port->dev);
 }
 
+static const char *const modes[] = {
+       [USB_DR_MODE_UNKNOWN] = "",
+       [USB_DR_MODE_HOST] = "host",
+       [USB_DR_MODE_PERIPHERAL] = "peripheral",
+       [USB_DR_MODE_OTG] = "otg",
+};
+
 static int tegra_xusb_usb2_port_parse_dt(struct tegra_xusb_usb2_port *usb2)
 {
        struct tegra_xusb_port *port = &usb2->base;
        struct device_node *np = port->dev.of_node;
+       const char *mode;
 
        usb2->internal = of_property_read_bool(np, "nvidia,internal");
 
+       if (!of_property_read_string(np, "mode", &mode)) {
+               int err = match_string(modes, ARRAY_SIZE(modes), mode);
+               if (err < 0) {
+                       dev_err(&port->dev, "invalid value %s for \"mode\"\n",
+                               mode);
+                       usb2->mode = USB_DR_MODE_UNKNOWN;
+               } else {
+                       usb2->mode = err;
+               }
+       } else {
+               usb2->mode = USB_DR_MODE_HOST;
+       }
+
        usb2->supply = devm_regulator_get(&port->dev, "vbus");
        return PTR_ERR_OR_ZERO(usb2->supply);
 }
index b49dbc36efa32e006e9acd9a189e627181756639..bb60fc09c7528dc3e112742b82cf28d3bc23a905 100644 (file)
@@ -19,6 +19,8 @@
 #include <linux/mutex.h>
 #include <linux/workqueue.h>
 
+#include <linux/usb/otg.h>
+
 /* legacy entry points for backwards-compatibility */
 int tegra_xusb_padctl_legacy_probe(struct platform_device *pdev);
 int tegra_xusb_padctl_legacy_remove(struct platform_device *pdev);
@@ -271,6 +273,7 @@ struct tegra_xusb_usb2_port {
        struct tegra_xusb_port base;
 
        struct regulator *supply;
+       enum usb_dr_mode mode;
        bool internal;
 };