From fca3d4b1074fbc3ca74db040f6abdf9b614df819 Mon Sep 17 00:00:00 2001
From: Liu Ying <victor.liu@nxp.com>
Date: Fri, 13 Oct 2017 11:47:51 +0800
Subject: [PATCH] MLK-16581-2 phy: mixel-lvds-combo: Get PHY clock rate before
 setting it's rate

Due to i.MX8 clock issue, we need to get PHY clock rate
before setting it's rate when system resumes back from
PM sleep mode, otherwise, we'll fail to set the clock rate.
So, this is a workaround and it can be removed when
the clock issue is properly fixed.

Signed-off-by: Liu Ying <victor.liu@nxp.com>
---
 drivers/phy/phy-mixel-lvds-combo.c | 7 +++++++
 1 file changed, 7 insertions(+)

diff --git a/drivers/phy/phy-mixel-lvds-combo.c b/drivers/phy/phy-mixel-lvds-combo.c
index 9d3d469872903a..3b888b110e0d10 100644
--- a/drivers/phy/phy-mixel-lvds-combo.c
+++ b/drivers/phy/phy-mixel-lvds-combo.c
@@ -96,6 +96,13 @@ void mixel_phy_combo_lvds_set_phy_speed(struct phy *phy,
 {
 	struct mixel_lvds_phy *lvds_phy = phy_get_drvdata(phy);
 
+	/*
+	 * To workaround setting clock rate failure issue
+	 * when the system resumes back from PM sleep mode,
+	 * we need to get the clock rate before setting it's
+	 * rate, otherwise, setting the clock rate will fail.
+	 */
+	clk_get_rate(lvds_phy->phy_clk);
 	clk_set_rate(lvds_phy->phy_clk, phy_clk_rate);
 }
 EXPORT_SYMBOL_GPL(mixel_phy_combo_lvds_set_phy_speed);
-- 
GitLab