All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] usb: dwc3-meson-g12a: fix usb2 PHY glue init when phy0 is disabled
@ 2021-06-01  8:48 ` Neil Armstrong
  0 siblings, 0 replies; 21+ messages in thread
From: Neil Armstrong @ 2021-06-01  8:48 UTC (permalink / raw)
  To: balbi
  Cc: linux-usb, linux-amlogic, linux-arm-kernel, linux-kernel, Neil Armstrong

When only PHY1 is used (for example on Odroid-HC4), the regmap init code
uses the usb2 ports when doesn't initialize the PHY1 regmap entry.

This fixes:
Unable to handle kernel NULL pointer dereference at virtual address 0000000000000020
...
pc : regmap_update_bits_base+0x40/0xa0
lr : dwc3_meson_g12a_usb2_init_phy+0x4c/0xf8
...
Call trace:
regmap_update_bits_base+0x40/0xa0
dwc3_meson_g12a_usb2_init_phy+0x4c/0xf8
dwc3_meson_g12a_usb2_init+0x7c/0xc8
dwc3_meson_g12a_usb_init+0x28/0x48
dwc3_meson_g12a_probe+0x298/0x540
platform_probe+0x70/0xe0
really_probe+0xf0/0x4d8
driver_probe_device+0xfc/0x168
...

Fixes: 013af227f58a97 ("usb: dwc3: meson-g12a: handle the phy and glue registers separately")
Signed-off-by: Neil Armstrong <narmstrong@baylibre.com>
---
 drivers/usb/dwc3/dwc3-meson-g12a.c | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)

diff --git a/drivers/usb/dwc3/dwc3-meson-g12a.c b/drivers/usb/dwc3/dwc3-meson-g12a.c
index bdf1f98dfad8..9c944bc6d555 100644
--- a/drivers/usb/dwc3/dwc3-meson-g12a.c
+++ b/drivers/usb/dwc3/dwc3-meson-g12a.c
@@ -651,7 +651,7 @@ static int dwc3_meson_g12a_setup_regmaps(struct dwc3_meson_g12a *priv,
 		return PTR_ERR(priv->usb_glue_regmap);
 
 	/* Create a regmap for each USB2 PHY control register set */
-	for (i = 0; i < priv->usb2_ports; i++) {
+	for (i = 0; i < priv->drvdata->num_phys; i++) {
 		struct regmap_config u2p_regmap_config = {
 			.reg_bits = 8,
 			.val_bits = 32,
@@ -659,6 +659,9 @@ static int dwc3_meson_g12a_setup_regmaps(struct dwc3_meson_g12a *priv,
 			.max_register = U2P_R1,
 		};
 
+		if (!strstr(priv->drvdata->phy_names[i], "usb2"))
+			continue;
+
 		u2p_regmap_config.name = devm_kasprintf(priv->dev, GFP_KERNEL,
 							"u2p-%d", i);
 		if (!u2p_regmap_config.name)
-- 
2.25.1


^ permalink raw reply related	[flat|nested] 21+ messages in thread

end of thread, other threads:[~2021-06-07  6:49 UTC | newest]

Thread overview: 21+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-06-01  8:48 [PATCH] usb: dwc3-meson-g12a: fix usb2 PHY glue init when phy0 is disabled Neil Armstrong
2021-06-01  8:48 ` Neil Armstrong
2021-06-01  8:48 ` Neil Armstrong
2021-06-03 18:20 ` Martin Blumenstingl
2021-06-03 18:20   ` Martin Blumenstingl
2021-06-03 18:20   ` Martin Blumenstingl
2021-06-04 10:58 ` Greg KH
2021-06-04 10:58   ` Greg KH
2021-06-04 10:58   ` Greg KH
2021-06-04 15:07   ` Konstantin Ryabitsev
2021-06-04 15:07     ` Konstantin Ryabitsev
2021-06-04 15:07     ` Konstantin Ryabitsev
2021-06-04 16:46     ` Konstantin Ryabitsev
2021-06-04 16:46       ` Konstantin Ryabitsev
2021-06-04 16:46       ` Konstantin Ryabitsev
2021-06-05  7:02       ` Greg KH
2021-06-05  7:02         ` Greg KH
2021-06-05  7:02         ` Greg KH
2021-06-07  6:46       ` Neil Armstrong
2021-06-07  6:46         ` Neil Armstrong
2021-06-07  6:46         ` Neil Armstrong

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.