diff options
| author | Tim Harvey <tharvey@gateworks.com> | 2025-07-21 11:02:05 -0700 | 
|---|---|---|
| committer | Marek Vasut <marek.vasut+usb@mailbox.org> | 2025-08-23 18:17:59 +0200 | 
| commit | 445aad45f47a19860eff5b09c4c570285265318a (patch) | |
| tree | d87a0689dfeea486a1f78a584639022e665d3f95 | |
| parent | edbcf8e3590fb640b4709841605b0a58ef8aa7f1 (diff) | |
usb: ehci-mx6: Add i.MX95 OTG support
When the usb node is defined dr_mode="otg" ehci_usb_phy_mode() is called
to determine the mode from status registers.
The IMX95RM does not currently define the USBNC STATUS register but it is
assumed to be an omission as the first three registers are defined.
It has been expirimentally verified that the USBNC_PHY_STATUS register
at offset 0x23C bit4 (USBNC_PHYSTATUS_ID_DIG) reads 0 when USB_ID is GND
and 1 when floating.
Use is_imx9() as this driver works for i.MX91, i.MX93 and i.MX95 and all
of these determine the role based on the USBNC_PHY_STATUS register.
Fixes: 801b5fafd35d "(usb: ehci-mx6: Add i.MX95 support")
Signed-off-by: Tim Harvey <tharvey@gateworks.com>
Reviewed-by: Alice Guo <alice.guo@nxp.com>
Reviewed-by: Peng Fan <peng.fan@nxp.com>
Reviewed-by: Fabio Estevam <festevam@gmail.com>
| -rw-r--r-- | drivers/usb/host/ehci-mx6.c | 2 | 
1 files changed, 1 insertions, 1 deletions
| diff --git a/drivers/usb/host/ehci-mx6.c b/drivers/usb/host/ehci-mx6.c index a8748cef7ad..25907f22612 100644 --- a/drivers/usb/host/ehci-mx6.c +++ b/drivers/usb/host/ehci-mx6.c @@ -537,7 +537,7 @@ static int ehci_usb_phy_mode(struct udevice *dev)  			plat->init_type = USB_INIT_DEVICE;  		else  			plat->init_type = USB_INIT_HOST; -	} else if (is_mx7() || is_imx8mm() || is_imx8mn() || is_imx93()) { +	} else if (is_mx7() || is_imx8mm() || is_imx8mn() || is_imx9()) {  		phy_status = (void __iomem *)(addr +  					      USBNC_PHY_STATUS_OFFSET);  		val = readl(phy_status); | 
