Lines Matching +full:tuning +full:- +full:start +full:- +full:tap
1 // SPDX-License-Identifier: GPL-2.0-only
5 * Copyright (C) 2016 Shawn Lin <shawn.lin@rock-chips.com>
20 * The higher 16-bit of this register is used for write protection
98 regmap_write(rk_phy->reg_base, in rockchip_emmc_phy_power()
99 rk_phy->reg_offset + GRF_EMMCPHY_CON6, in rockchip_emmc_phy_power()
103 regmap_write(rk_phy->reg_base, in rockchip_emmc_phy_power()
104 rk_phy->reg_offset + GRF_EMMCPHY_CON6, in rockchip_emmc_phy_power()
113 rate = clk_get_rate(rk_phy->emmcclk); in rockchip_emmc_phy_power()
138 rate - ideal_rate : ideal_rate - rate; in rockchip_emmc_phy_power()
141 * In order for tuning delays to be accurate we need to be in rockchip_emmc_phy_power()
144 * warn for really slow rates since we won't be tuning then. in rockchip_emmc_phy_power()
147 dev_warn(&phy->dev, "Unsupported rate: %lu\n", rate); in rockchip_emmc_phy_power()
156 regmap_write(rk_phy->reg_base, in rockchip_emmc_phy_power()
157 rk_phy->reg_offset + GRF_EMMCPHY_CON6, in rockchip_emmc_phy_power()
169 ret = regmap_read_poll_timeout(rk_phy->reg_base, in rockchip_emmc_phy_power()
170 rk_phy->reg_offset + GRF_EMMCPHY_STATUS, in rockchip_emmc_phy_power()
179 regmap_write(rk_phy->reg_base, in rockchip_emmc_phy_power()
180 rk_phy->reg_offset + GRF_EMMCPHY_CON0, in rockchip_emmc_phy_power()
185 regmap_write(rk_phy->reg_base, in rockchip_emmc_phy_power()
186 rk_phy->reg_offset + GRF_EMMCPHY_CON6, in rockchip_emmc_phy_power()
217 ret = regmap_read_poll_timeout(rk_phy->reg_base, in rockchip_emmc_phy_power()
218 rk_phy->reg_offset + GRF_EMMCPHY_STATUS, in rockchip_emmc_phy_power()
237 * - PHY driver to probe in rockchip_emmc_phy_init()
238 * - SDHCI driver to start probe in rockchip_emmc_phy_init()
239 * - SDHCI driver to register it's clock in rockchip_emmc_phy_init()
240 * - SDHCI driver to get the PHY in rockchip_emmc_phy_init()
241 * - SDHCI driver to init the PHY in rockchip_emmc_phy_init()
249 rk_phy->emmcclk = clk_get(&phy->dev, "emmcclk"); in rockchip_emmc_phy_init()
250 if (IS_ERR(rk_phy->emmcclk)) { in rockchip_emmc_phy_init()
251 dev_dbg(&phy->dev, "Error getting emmcclk: %d\n", ret); in rockchip_emmc_phy_init()
252 rk_phy->emmcclk = NULL; in rockchip_emmc_phy_init()
262 clk_put(rk_phy->emmcclk); in rockchip_emmc_phy_exit()
278 regmap_write(rk_phy->reg_base, in rockchip_emmc_phy_power_on()
279 rk_phy->reg_offset + GRF_EMMCPHY_CON6, in rockchip_emmc_phy_power_on()
280 HIWORD_UPDATE(rk_phy->drive_impedance, in rockchip_emmc_phy_power_on()
284 /* Output tap delay: enable */ in rockchip_emmc_phy_power_on()
285 regmap_write(rk_phy->reg_base, in rockchip_emmc_phy_power_on()
286 rk_phy->reg_offset + GRF_EMMCPHY_CON0, in rockchip_emmc_phy_power_on()
291 /* Output tap delay */ in rockchip_emmc_phy_power_on()
292 regmap_write(rk_phy->reg_base, in rockchip_emmc_phy_power_on()
293 rk_phy->reg_offset + GRF_EMMCPHY_CON0, in rockchip_emmc_phy_power_on()
325 dev_warn(&pdev->dev, "Invalid value %u for drive-impedance-ohm.\n", in convert_drive_impedance_ohm()
332 struct device *dev = &pdev->dev; in rockchip_emmc_phy_probe()
340 if (!dev->parent || !dev->parent->of_node) in rockchip_emmc_phy_probe()
341 return -ENODEV; in rockchip_emmc_phy_probe()
343 grf = syscon_node_to_regmap(dev->parent->of_node); in rockchip_emmc_phy_probe()
351 return -ENOMEM; in rockchip_emmc_phy_probe()
353 if (of_property_read_u32(dev->of_node, "reg", ®_offset)) { in rockchip_emmc_phy_probe()
355 dev->of_node); in rockchip_emmc_phy_probe()
356 return -EINVAL; in rockchip_emmc_phy_probe()
359 rk_phy->reg_offset = reg_offset; in rockchip_emmc_phy_probe()
360 rk_phy->reg_base = grf; in rockchip_emmc_phy_probe()
361 rk_phy->drive_impedance = PHYCTRL_DR_50OHM; in rockchip_emmc_phy_probe()
363 if (!of_property_read_u32(dev->of_node, "drive-impedance-ohm", &val)) in rockchip_emmc_phy_probe()
364 rk_phy->drive_impedance = convert_drive_impedance_ohm(pdev, val); in rockchip_emmc_phy_probe()
366 generic_phy = devm_phy_create(dev, dev->of_node, &ops); in rockchip_emmc_phy_probe()
379 { .compatible = "rockchip,rk3399-emmc-phy" },
388 .name = "rockchip-emmc-phy",
395 MODULE_AUTHOR("Shawn Lin <shawn.lin@rock-chips.com>");