PCI: imx6: Simplify imx7d_pcie_wait_for_phy_pll_lock()
Make use of regmap_read_poll_timeout() to simplify imx7d_pcie_wait_for_phy_pll_lock(). No functional change intended. Signed-off-by: Andrey Smirnov <andrew.smirnov@gmail.com> Signed-off-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com> Reviewed-by: Lucas Stach <l.stach@pengutronix.de> Cc: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com> Cc: Bjorn Helgaas <bhelgaas@google.com> Cc: Chris Healy <cphealy@gmail.com> Cc: Lucas Stach <l.stach@pengutronix.de> Cc: linux-kernel@vger.kernel.org Cc: linux-pci@vger.kernel.org
This commit is contained in:
committed by
Lorenzo Pieralisi
parent
9e98c678c2
commit
9e303be2e5
@@ -89,9 +89,8 @@ struct imx6_pcie {
|
|||||||
};
|
};
|
||||||
|
|
||||||
/* Parameters for the waiting for PCIe PHY PLL to lock on i.MX7 */
|
/* Parameters for the waiting for PCIe PHY PLL to lock on i.MX7 */
|
||||||
#define PHY_PLL_LOCK_WAIT_MAX_RETRIES 2000
|
|
||||||
#define PHY_PLL_LOCK_WAIT_USLEEP_MIN 50
|
|
||||||
#define PHY_PLL_LOCK_WAIT_USLEEP_MAX 200
|
#define PHY_PLL_LOCK_WAIT_USLEEP_MAX 200
|
||||||
|
#define PHY_PLL_LOCK_WAIT_TIMEOUT (2000 * PHY_PLL_LOCK_WAIT_USLEEP_MAX)
|
||||||
|
|
||||||
/* PCIe Root Complex registers (memory-mapped) */
|
/* PCIe Root Complex registers (memory-mapped) */
|
||||||
#define PCIE_RC_IMX6_MSI_CAP 0x50
|
#define PCIE_RC_IMX6_MSI_CAP 0x50
|
||||||
@@ -488,20 +487,14 @@ static int imx6_pcie_enable_ref_clk(struct imx6_pcie *imx6_pcie)
|
|||||||
static void imx7d_pcie_wait_for_phy_pll_lock(struct imx6_pcie *imx6_pcie)
|
static void imx7d_pcie_wait_for_phy_pll_lock(struct imx6_pcie *imx6_pcie)
|
||||||
{
|
{
|
||||||
u32 val;
|
u32 val;
|
||||||
unsigned int retries;
|
|
||||||
struct device *dev = imx6_pcie->pci->dev;
|
struct device *dev = imx6_pcie->pci->dev;
|
||||||
|
|
||||||
for (retries = 0; retries < PHY_PLL_LOCK_WAIT_MAX_RETRIES; retries++) {
|
if (regmap_read_poll_timeout(imx6_pcie->iomuxc_gpr,
|
||||||
regmap_read(imx6_pcie->iomuxc_gpr, IOMUXC_GPR22, &val);
|
IOMUXC_GPR22, val,
|
||||||
|
val & IMX7D_GPR22_PCIE_PHY_PLL_LOCKED,
|
||||||
if (val & IMX7D_GPR22_PCIE_PHY_PLL_LOCKED)
|
PHY_PLL_LOCK_WAIT_USLEEP_MAX,
|
||||||
return;
|
PHY_PLL_LOCK_WAIT_TIMEOUT))
|
||||||
|
dev_err(dev, "PCIe PLL lock timeout\n");
|
||||||
usleep_range(PHY_PLL_LOCK_WAIT_USLEEP_MIN,
|
|
||||||
PHY_PLL_LOCK_WAIT_USLEEP_MAX);
|
|
||||||
}
|
|
||||||
|
|
||||||
dev_err(dev, "PCIe PLL lock timeout\n");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void imx6_pcie_deassert_core_reset(struct imx6_pcie *imx6_pcie)
|
static void imx6_pcie_deassert_core_reset(struct imx6_pcie *imx6_pcie)
|
||||||
|
|||||||
Reference in New Issue
Block a user