Commit 40f2f2a3 authored by Joachim Eastwood's avatar Joachim Eastwood Committed by Greg Kroah-Hartman

USB: ehci-platform: support EHCIs with transaction translator

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: default avatarJoachim Eastwood <manabian@gmail.com>
Acked-by: default avatarAlan Stern <stern@rowland.harvard.edu>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent ca07e1c1
...@@ -13,6 +13,8 @@ Optional properties: ...@@ -13,6 +13,8 @@ Optional properties:
- big-endian-desc : boolean, set this for hcds with big-endian descriptors - big-endian-desc : boolean, set this for hcds with big-endian descriptors
- big-endian : boolean, for hcds with big-endian-regs + big-endian-desc - 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 - 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 - clocks : a list of phandle + clock specifier pairs
- phys : phandle + phy specifier pair - phys : phandle + phy specifier pair
- phy-names : "usb" - phy-names : "usb"
......
...@@ -202,6 +202,10 @@ static int ehci_platform_probe(struct platform_device *dev) ...@@ -202,6 +202,10 @@ static int ehci_platform_probe(struct platform_device *dev)
"needs-reset-on-resume")) "needs-reset-on-resume"))
pdata->reset_on_resume = 1; 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, priv->num_phys = of_count_phandle_with_args(dev->dev.of_node,
"phys", "#phy-cells"); "phys", "#phy-cells");
priv->num_phys = priv->num_phys > 0 ? priv->num_phys : 1; priv->num_phys = priv->num_phys > 0 ? priv->num_phys : 1;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment