Merge tag 'usb-for-v5.7' of git://git.kernel.org/pub/scm/linux/kernel/git/balbi/usb...
authorGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 16 Mar 2020 07:22:49 +0000 (08:22 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 16 Mar 2020 07:22:49 +0000 (08:22 +0100)
Felipe writes:

USB: changes for v5.7 merge window

Lots of changes on dwc3 this time, most of them from Thinh fixing a
bunch of really old mishaps on the driver.

DWC2 got support for STM32MP15 and a couple RockChip SoCs while DWC3
learned about Amlogic A1 family.

Apart from these, we have a few spelling fixes and other minor
non-critical fixes all over the place.

Signed-off-by: Felipe Balbi <balbi@kernel.org>
* tag 'usb-for-v5.7' of git://git.kernel.org/pub/scm/linux/kernel/git/balbi/usb: (41 commits)
  dt-bindings: usb: add documentation for aspeed usb-vhub
  ARM: dts: aspeed-g4: add vhub port and endpoint properties
  ARM: dts: aspeed-g5: add vhub port and endpoint properties
  ARM: dts: aspeed-g6: add usb functions
  usb: gadget: aspeed: add ast2600 vhub support
  usb: gadget: aspeed: read vhub properties from device tree
  usb: gadget: aspeed: support per-vhub usb descriptors
  usb: gadget: f_phonet: Replace zero-length array with flexible-array member
  usb: gadget: composite: Inform controller driver of self-powered
  usb: gadget: amd5536udc: fix spelling mistake "reserverd" -> "reserved"
  udc: s3c-hsudc: Silence warning about supplies during deferred probe
  usb: dwc2: Silence warning about supplies during deferred probe
  dt-bindings: usb: dwc2: add compatible property for rk3368 usb
  dt-bindings: usb: dwc2: add compatible property for rk3328 usb
  usb: gadget: add raw-gadget interface
  usb: dwc2: Implement set_selfpowered()
  usb: dwc3: qcom: Replace <linux/clk-provider.h> by <linux/of_clk.h>
  usb: dwc3: core: don't do suspend for device mode if already suspended
  usb: dwc3: Rework resets initialization to be more flexible
  usb: dwc3: Rework clock initialization to be more flexible
  ...

1  2 
drivers/usb/dwc3/dwc3-meson-g12a.c
drivers/usb/gadget/udc/tegra-xudc.c

@@@ -381,6 -408,53 +409,54 @@@ static struct device *dwc3_meson_g12_fi
        return &pdev->dev;
  }
  
+ static int dwc3_meson_g12a_otg_init(struct platform_device *pdev,
+                                   struct dwc3_meson_g12a *priv)
+ {
+       enum phy_mode otg_id;
+       int ret, irq;
+       struct device *dev = &pdev->dev;
+       if (!priv->drvdata->otg_switch_supported)
+               return 0;
+       if (priv->otg_mode == USB_DR_MODE_OTG) {
+               /* Ack irq before registering */
+               regmap_update_bits(priv->regmap, USB_R5,
+                                  USB_R5_ID_DIG_IRQ, 0);
+               irq = platform_get_irq(pdev, 0);
+               ret = devm_request_threaded_irq(&pdev->dev, irq, NULL,
+                                               dwc3_meson_g12a_irq_thread,
+                                               IRQF_ONESHOT, pdev->name, priv);
+               if (ret)
+                       return ret;
+       }
+       /* Setup OTG mode corresponding to the ID pin */
+       if (priv->otg_mode == USB_DR_MODE_OTG) {
+               otg_id = dwc3_meson_g12a_get_id(priv);
+               if (otg_id != priv->otg_phy_mode) {
+                       if (dwc3_meson_g12a_otg_mode_set(priv, otg_id))
+                               dev_warn(dev, "Failed to switch OTG mode\n");
+               }
+       }
+       /* Setup role switcher */
+       priv->switch_desc.usb2_port = dwc3_meson_g12_find_child(dev,
+                                                               "snps,dwc3");
+       priv->switch_desc.udc = dwc3_meson_g12_find_child(dev, "snps,dwc2");
+       priv->switch_desc.allow_userspace_control = true;
+       priv->switch_desc.set = dwc3_meson_g12a_role_set;
+       priv->switch_desc.get = dwc3_meson_g12a_role_get;
++      priv->switch_desc.driver_data = priv;
+       priv->role_switch = usb_role_switch_register(dev, &priv->switch_desc);
+       if (IS_ERR(priv->role_switch))
+               dev_warn(dev, "Unable to register Role Switch\n");
+       return 0;
+ }
  static int dwc3_meson_g12a_probe(struct platform_device *pdev)
  {
        struct dwc3_meson_g12a  *priv;
Simple merge