USB: ehci-platform: support EHCIs with transaction translator
authorJoachim Eastwood <manabian@gmail.com>
Sat, 16 May 2015 15:17:40 +0000 (17:17 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sun, 24 May 2015 16:29:36 +0000 (09:29 -0700)
Some EHCI controllers have a Transaction Translator built into
the root hub. Support this feature in device tree when using
the ehci-platform driver by adding a feature flag for it.

This is needed to get USB working on NXP LPC18xx/43xx platforms.

Signed-off-by: Joachim Eastwood <manabian@gmail.com>
Acked-by: Alan Stern <stern@rowland.harvard.edu>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Documentation/devicetree/bindings/usb/usb-ehci.txt
drivers/usb/host/ehci-platform.c

index 0b04fdff9d5aae8ee8ed0425aeb9c7ab7026eed4..a12d6012a40fd6acbdbe733a68935dd6196d52c2 100644 (file)
@@ -13,6 +13,8 @@ Optional properties:
  - big-endian-desc : boolean, set this for hcds with big-endian descriptors
  - big-endian : boolean, for hcds with big-endian-regs + big-endian-desc
  - needs-reset-on-resume : boolean, set this to force EHCI reset after resume
+ - has-transaction-translator : boolean, set this if EHCI have a Transaction
+                               Translator built into the root hub.
  - clocks : a list of phandle + clock specifier pairs
  - phys : phandle + phy specifier pair
  - phy-names : "usb"
index d8a75a51d6d4f8b9e2430fd1583cf41817f63e60..ba07f16b13e09c34c30c8e83a68f3da0aec48d20 100644 (file)
@@ -202,6 +202,10 @@ static int ehci_platform_probe(struct platform_device *dev)
                                          "needs-reset-on-resume"))
                        pdata->reset_on_resume = 1;
 
+               if (of_property_read_bool(dev->dev.of_node,
+                                         "has-transaction-translator"))
+                       pdata->has_tt = 1;
+
                priv->num_phys = of_count_phandle_with_args(dev->dev.of_node,
                                "phys", "#phy-cells");
                priv->num_phys = priv->num_phys > 0 ? priv->num_phys : 1;