Hi Amjad,
On Fri, Nov 13, 2020 at 1:07 AM Amjad Ouled-Ameur
<aouledameur@xxxxxxxxxxxx> wrote:
[...]
ret = clk_prepare_enable(priv->clk_usb);this should come after reset_control_rearm so we're cleaning up in
if (ret) {
dev_err(&phy->dev, "Failed to enable USB DDR clock\n");
+ reset_control_rearm(priv->reset);
reverse order of initializing things
(in this case it probably makes no difference since
reset_control_rearm is not touching any registers, but I'd still have
it in the correct order to not confuse future developers)
clk_disable_unprepare(priv->clk_usb_general);same here, reset_control_rearm should be after clk_disable_unprepare
return ret;
}
@@ -197,6 +199,7 @@ static int phy_meson8b_usb2_power_on(struct phy *phy)
regmap_read(priv->regmap, REG_ADP_BC, ®);
if (reg & REG_ADP_BC_ACA_PIN_FLOAT) {
dev_warn(&phy->dev, "USB ID detect failed!\n");
+ reset_control_rearm(priv->reset);
clk_disable_unprepare(priv->clk_usb);same here, reset_control_rearm should be after clk_disable_unprepare
clk_disable_unprepare(priv->clk_usb_general);
return -EINVAL;
@@ -216,6 +219,7 @@ static int phy_meson8b_usb2_power_off(struct phy *phy)
REG_DBG_UART_SET_IDDQ,
REG_DBG_UART_SET_IDDQ);
+ reset_control_rearm(priv->reset);
clk_disable_unprepare(priv->clk_usb);
clk_disable_unprepare(priv->clk_usb_general);
Best regards,
Martin