[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20250226103810.3746018-3-heiko@sntech.de>
Date: Wed, 26 Feb 2025 11:38:10 +0100
From: Heiko Stuebner <heiko@...ech.de>
To: vkoul@...nel.org,
kishon@...nel.org
Cc: heiko@...ech.de,
linux-phy@...ts.infradead.org,
linux-arm-kernel@...ts.infradead.org,
linux-rockchip@...ts.infradead.org,
linux-kernel@...r.kernel.org,
quentin.schulz@...rry.de,
sebastian.reichel@...labora.com,
christophe.jaillet@...adoo.fr,
Heiko Stuebner <heiko.stuebner@...rry.de>
Subject: [PATCH v2 2/2] phy: rockchip: usbdp: re-init the phy on orientation-change
From: Heiko Stuebner <heiko.stuebner@...rry.de>
Until now the usbdp in the orientation-handler set the new lane setup in
its internal state variables and adapted the sbu gpios as needed.
It never actually updated the phy itself though, but relied on the
controlling usb-controller to disable and re-enable the phy.
And while on the vendor-kernel, I could see that on every unplug the dwc3
did go to its suspend and woke up on the next device plug-in event,
thus toggling the phy as needed, this does not happen in all cases and we
should not rely on that behaviour.
This results in the usb2 always working, as it's not affected by the
orientation, but usb3 only working in one direction right now.
So similar to how the update works in the power-on callback, just re-init
the phy if it's already running when the orientation-event happens.
Both the power-on/-off functions as well as the orientation-set callback
work with the usbdp-mutex held, so can't conflict.
The behaviour is similar to how the qcom qmp phys handle the orientaton
re-init - by re-initting the phy.
Signed-off-by: Heiko Stuebner <heiko.stuebner@...rry.de>
---
drivers/phy/rockchip/phy-rockchip-usbdp.c | 7 ++++++-
1 file changed, 6 insertions(+), 1 deletion(-)
diff --git a/drivers/phy/rockchip/phy-rockchip-usbdp.c b/drivers/phy/rockchip/phy-rockchip-usbdp.c
index 960cad5b01a9..c07b79da5b6b 100644
--- a/drivers/phy/rockchip/phy-rockchip-usbdp.c
+++ b/drivers/phy/rockchip/phy-rockchip-usbdp.c
@@ -1277,6 +1277,7 @@ static int rk_udphy_orien_sw_set(struct typec_switch_dev *sw,
enum typec_orientation orien)
{
struct rk_udphy *udphy = typec_switch_get_drvdata(sw);
+ int ret = 0;
mutex_lock(&udphy->mutex);
@@ -1292,9 +1293,13 @@ static int rk_udphy_orien_sw_set(struct typec_switch_dev *sw,
rk_udphy_set_typec_default_mapping(udphy);
rk_udphy_usb_bvalid_enable(udphy, true);
+ /* re-init the phy if already on */
+ if (udphy->status != UDPHY_MODE_NONE)
+ ret = rk_udphy_init(udphy);
+
unlock_ret:
mutex_unlock(&udphy->mutex);
- return 0;
+ return ret;
}
static void rk_udphy_orien_switch_unregister(void *data)
--
2.47.2
Powered by blists - more mailing lists