Lines Matching +full:keembay +full:- +full:emmc +full:- +full:phy
1 // SPDX-License-Identifier: GPL-2.0-or-later
4 * Copyright (C) 2011 - 2012 Michal Simek <monstr@monstr.eu>
9 * Based on sdhci-of-esdhc.c
18 #include <linux/clk-provider.h>
22 #include <linux/phy/phy.h>
25 #include <linux/firmware/xlnx-zynqmp.h>
28 #include "sdhci-cqhci.h"
29 #include "sdhci-pltfm.h"
56 * On some SoCs the syscon area has a feature where the upper 16-bits of
57 * each 32-bit register act as a write mask for the lower 16-bits. This allows
65 * struct sdhci_arasan_soc_ctl_field - Field used in sdhci_arasan_soc_ctl_map
69 * @shift: Bit offset within @reg of this field (or -1 if not avail)
78 * struct sdhci_arasan_soc_ctl_map - Map in syscon to corecfg registers
97 * struct sdhci_arasan_clk_ops - Clock Operations for Arasan SD controller
108 * struct sdhci_arasan_clk_data - Arasan Controller Clock Data.
110 * @sdcardclk_hw: Struct for the clock we might provide to a PHY.
112 * @sampleclk_hw: Struct for the clock we might provide to a PHY.
131 * struct sdhci_arasan_data - Arasan Controller Data
135 * @phy: Pointer to the generic phy
136 * @is_phy_on: True if the PHY is on; false if not.
147 struct phy *phy; member
185 .clockmultiplier = { .reg = 0, .width = -1, .shift = -1 },
191 .clockmultiplier = { .reg = 0, .width = -1, .shift = -1 },
210 * sdhci_arasan_syscon_write - Write to a field in soc_ctl registers
229 struct regmap *soc_ctl_base = sdhci_arasan->soc_ctl_base; in sdhci_arasan_syscon_write()
230 u32 reg = fld->reg; in sdhci_arasan_syscon_write()
231 u16 width = fld->width; in sdhci_arasan_syscon_write()
232 s16 shift = fld->shift; in sdhci_arasan_syscon_write()
242 return -EINVAL; in sdhci_arasan_syscon_write()
244 if (sdhci_arasan->soc_ctl_map->hiword_update) in sdhci_arasan_syscon_write()
256 mmc_hostname(host->mmc), ret); in sdhci_arasan_syscon_write()
265 struct sdhci_arasan_clk_data *clk_data = &sdhci_arasan->clk_data; in sdhci_arasan_set_clock()
268 if (!IS_ERR(sdhci_arasan->phy)) { in sdhci_arasan_set_clock()
269 if (!sdhci_arasan->is_phy_on && clock <= PHY_CLK_TOO_SLOW_HZ) { in sdhci_arasan_set_clock()
271 * If PHY off, set clock to max speed and power PHY on. in sdhci_arasan_set_clock()
273 * Although PHY docs apparently suggest power cycling in sdhci_arasan_set_clock()
274 * when changing the clock the PHY doesn't like to be in sdhci_arasan_set_clock()
276 * mode. Even worse is powering the PHY on while the in sdhci_arasan_set_clock()
279 * To workaround the PHY limitations, the best we can in sdhci_arasan_set_clock()
283 sdhci_set_clock(host, host->max_clk); in sdhci_arasan_set_clock()
284 if (phy_power_on(sdhci_arasan->phy)) { in sdhci_arasan_set_clock()
285 pr_err("%s: Cannot power on phy.\n", in sdhci_arasan_set_clock()
286 mmc_hostname(host->mmc)); in sdhci_arasan_set_clock()
290 sdhci_arasan->is_phy_on = true; in sdhci_arasan_set_clock()
299 * At higher clock speeds the PHY is fine being power in sdhci_arasan_set_clock()
307 if (ctrl_phy && sdhci_arasan->is_phy_on) { in sdhci_arasan_set_clock()
308 phy_power_off(sdhci_arasan->phy); in sdhci_arasan_set_clock()
309 sdhci_arasan->is_phy_on = false; in sdhci_arasan_set_clock()
312 if (sdhci_arasan->quirks & SDHCI_ARASAN_QUIRK_CLOCK_25_BROKEN) { in sdhci_arasan_set_clock()
323 if (clk_data->set_clk_delays) in sdhci_arasan_set_clock()
324 clk_data->set_clk_delays(host); in sdhci_arasan_set_clock()
328 if (sdhci_arasan->quirks & SDHCI_ARASAN_QUIRK_CLOCK_UNSTABLE) in sdhci_arasan_set_clock()
339 if (phy_power_on(sdhci_arasan->phy)) { in sdhci_arasan_set_clock()
340 pr_err("%s: Cannot power on phy.\n", in sdhci_arasan_set_clock()
341 mmc_hostname(host->mmc)); in sdhci_arasan_set_clock()
345 sdhci_arasan->is_phy_on = true; in sdhci_arasan_set_clock()
356 if (ios->enhanced_strobe) in sdhci_arasan_hs400_enhanced_strobe()
372 if (sdhci_arasan->quirks & SDHCI_ARASAN_QUIRK_FORCE_CDTEST) { in sdhci_arasan_reset()
382 switch (ios->signal_voltage) { in sdhci_arasan_voltage_switch()
398 return -EINVAL; in sdhci_arasan_voltage_switch()
419 cqhci_irq(host->mmc, intmask, cmd_error, data_error); in sdhci_arasan_cqhci_irq()
478 * sdhci_arasan_suspend - Suspend method for the driver
492 if (host->tuning_mode != SDHCI_TUNING_MODE_3) in sdhci_arasan_suspend()
493 mmc_retune_needed(host->mmc); in sdhci_arasan_suspend()
495 if (sdhci_arasan->has_cqe) { in sdhci_arasan_suspend()
496 ret = cqhci_suspend(host->mmc); in sdhci_arasan_suspend()
505 if (!IS_ERR(sdhci_arasan->phy) && sdhci_arasan->is_phy_on) { in sdhci_arasan_suspend()
506 ret = phy_power_off(sdhci_arasan->phy); in sdhci_arasan_suspend()
508 dev_err(dev, "Cannot power off phy.\n"); in sdhci_arasan_suspend()
514 sdhci_arasan->is_phy_on = false; in sdhci_arasan_suspend()
517 clk_disable(pltfm_host->clk); in sdhci_arasan_suspend()
518 clk_disable(sdhci_arasan->clk_ahb); in sdhci_arasan_suspend()
524 * sdhci_arasan_resume - Resume method for the driver
538 ret = clk_enable(sdhci_arasan->clk_ahb); in sdhci_arasan_resume()
544 ret = clk_enable(pltfm_host->clk); in sdhci_arasan_resume()
550 if (!IS_ERR(sdhci_arasan->phy) && host->mmc->actual_clock) { in sdhci_arasan_resume()
551 ret = phy_power_on(sdhci_arasan->phy); in sdhci_arasan_resume()
553 dev_err(dev, "Cannot power on phy.\n"); in sdhci_arasan_resume()
556 sdhci_arasan->is_phy_on = true; in sdhci_arasan_resume()
565 if (sdhci_arasan->has_cqe) in sdhci_arasan_resume()
566 return cqhci_resume(host->mmc); in sdhci_arasan_resume()
576 * sdhci_arasan_sdcardclk_recalc_rate - Return the card clock rate
582 * to communicate with out PHY.
593 struct sdhci_host *host = sdhci_arasan->host; in sdhci_arasan_sdcardclk_recalc_rate()
595 return host->mmc->actual_clock; in sdhci_arasan_sdcardclk_recalc_rate()
603 * sdhci_arasan_sampleclk_recalc_rate - Return the sampling clock rate
609 * to communicate with out PHY.
620 struct sdhci_host *host = sdhci_arasan->host; in sdhci_arasan_sampleclk_recalc_rate()
622 return host->mmc->actual_clock; in sdhci_arasan_sampleclk_recalc_rate()
630 * sdhci_zynqmp_sdcardclk_set_phase - Set the SD Output Clock Tap Delays
633 * @degrees: The clock phase shift between 0 - 359.
645 struct sdhci_host *host = sdhci_arasan->host; in sdhci_zynqmp_sdcardclk_set_phase()
652 if (host->version < SDHCI_SPEC_300) in sdhci_zynqmp_sdcardclk_set_phase()
655 switch (host->timing) { in sdhci_zynqmp_sdcardclk_set_phase()
696 * sdhci_zynqmp_sampleclk_set_phase - Set the SD Input Clock Tap Delays
699 * @degrees: The clock phase shift between 0 - 359.
711 struct sdhci_host *host = sdhci_arasan->host; in sdhci_zynqmp_sampleclk_set_phase()
718 if (host->version < SDHCI_SPEC_300) in sdhci_zynqmp_sampleclk_set_phase()
724 switch (host->timing) { in sdhci_zynqmp_sampleclk_set_phase()
762 * sdhci_versal_sdcardclk_set_phase - Set the SD Output Clock Tap Delays
765 * @degrees: The clock phase shift between 0 - 359.
777 struct sdhci_host *host = sdhci_arasan->host; in sdhci_versal_sdcardclk_set_phase()
781 if (host->version < SDHCI_SPEC_300) in sdhci_versal_sdcardclk_set_phase()
784 switch (host->timing) { in sdhci_versal_sdcardclk_set_phase()
829 * sdhci_versal_sampleclk_set_phase - Set the SD Input Clock Tap Delays
832 * @degrees: The clock phase shift between 0 - 359.
844 struct sdhci_host *host = sdhci_arasan->host; in sdhci_versal_sampleclk_set_phase()
848 if (host->version < SDHCI_SPEC_300) in sdhci_versal_sampleclk_set_phase()
851 switch (host->timing) { in sdhci_versal_sampleclk_set_phase()
920 struct clk_hw *hw = &sdhci_arasan->clk_data.sdcardclk_hw; in arasan_zynqmp_execute_tuning()
927 if (mmc->ios.timing == MMC_TIMING_UHS_DDR50) in arasan_zynqmp_execute_tuning()
942 * sdhci_arasan_update_clockmultiplier - Set corecfg_clockmultiplier
951 * - Many existing devices don't seem to do this and work fine. To keep
955 * - The value of corecfg_clockmultiplier should sync with that of corresponding
965 sdhci_arasan->soc_ctl_map; in sdhci_arasan_update_clockmultiplier()
972 if (!sdhci_arasan->soc_ctl_base) { in sdhci_arasan_update_clockmultiplier()
973 pr_warn("%s: Have regmap, but no soc-ctl-syscon\n", in sdhci_arasan_update_clockmultiplier()
974 mmc_hostname(host->mmc)); in sdhci_arasan_update_clockmultiplier()
978 sdhci_arasan_syscon_write(host, &soc_ctl_map->clockmultiplier, value); in sdhci_arasan_update_clockmultiplier()
982 * sdhci_arasan_update_baseclkfreq - Set corecfg_baseclkfreq
990 * - Many existing devices don't seem to do this and work fine. To keep
994 * - It's assumed that clk_xin is not dynamic and that we use the SDHCI divider
1003 sdhci_arasan->soc_ctl_map; in sdhci_arasan_update_baseclkfreq()
1004 u32 mhz = DIV_ROUND_CLOSEST_ULL(clk_get_rate(pltfm_host->clk), 1000000); in sdhci_arasan_update_baseclkfreq()
1011 if (!sdhci_arasan->soc_ctl_base) { in sdhci_arasan_update_baseclkfreq()
1012 pr_warn("%s: Have regmap, but no soc-ctl-syscon\n", in sdhci_arasan_update_baseclkfreq()
1013 mmc_hostname(host->mmc)); in sdhci_arasan_update_baseclkfreq()
1017 sdhci_arasan_syscon_write(host, &soc_ctl_map->baseclkfreq, mhz); in sdhci_arasan_update_baseclkfreq()
1024 struct sdhci_arasan_clk_data *clk_data = &sdhci_arasan->clk_data; in sdhci_arasan_set_clk_delays()
1026 clk_set_phase(clk_data->sampleclk, in sdhci_arasan_set_clk_delays()
1027 clk_data->clk_phase_in[host->timing]); in sdhci_arasan_set_clk_delays()
1028 clk_set_phase(clk_data->sdcardclk, in sdhci_arasan_set_clk_delays()
1029 clk_data->clk_phase_out[host->timing]); in sdhci_arasan_set_clk_delays()
1036 struct device_node *np = dev->of_node; in arasan_dt_read_clk_phase()
1043 * Tap Values then use the pre-defined values. in arasan_dt_read_clk_phase()
1049 prop, clk_data->clk_phase_in[timing], in arasan_dt_read_clk_phase()
1050 clk_data->clk_phase_out[timing]); in arasan_dt_read_clk_phase()
1055 clk_data->clk_phase_in[timing] = clk_phase[0]; in arasan_dt_read_clk_phase()
1056 clk_data->clk_phase_out[timing] = clk_phase[1]; in arasan_dt_read_clk_phase()
1060 * arasan_dt_parse_clk_phases - Read Clock Delay values from DT
1078 clk_data->set_clk_delays = sdhci_arasan_set_clk_delays; in arasan_dt_parse_clk_phases()
1080 if (of_device_is_compatible(dev->of_node, "xlnx,zynqmp-8.9a")) { in arasan_dt_parse_clk_phases()
1086 of_property_read_u32(dev->of_node, "xlnx,mio-bank", &mio_bank); in arasan_dt_parse_clk_phases()
1093 clk_data->clk_phase_in[i] = zynqmp_iclk_phase[i]; in arasan_dt_parse_clk_phases()
1094 clk_data->clk_phase_out[i] = zynqmp_oclk_phase[i]; in arasan_dt_parse_clk_phases()
1098 if (of_device_is_compatible(dev->of_node, "xlnx,versal-8.9a")) { in arasan_dt_parse_clk_phases()
1105 clk_data->clk_phase_in[i] = versal_iclk_phase[i]; in arasan_dt_parse_clk_phases()
1106 clk_data->clk_phase_out[i] = versal_oclk_phase[i]; in arasan_dt_parse_clk_phases()
1111 "clk-phase-legacy"); in arasan_dt_parse_clk_phases()
1113 "clk-phase-mmc-hs"); in arasan_dt_parse_clk_phases()
1115 "clk-phase-sd-hs"); in arasan_dt_parse_clk_phases()
1117 "clk-phase-uhs-sdr12"); in arasan_dt_parse_clk_phases()
1119 "clk-phase-uhs-sdr25"); in arasan_dt_parse_clk_phases()
1121 "clk-phase-uhs-sdr50"); in arasan_dt_parse_clk_phases()
1123 "clk-phase-uhs-sdr104"); in arasan_dt_parse_clk_phases()
1125 "clk-phase-uhs-ddr50"); in arasan_dt_parse_clk_phases()
1127 "clk-phase-mmc-ddr52"); in arasan_dt_parse_clk_phases()
1129 "clk-phase-mmc-hs200"); in arasan_dt_parse_clk_phases()
1131 "clk-phase-mmc-hs400"); in arasan_dt_parse_clk_phases()
1266 /* SoC-specific compatible strings w/ soc_ctl_map */
1268 .compatible = "rockchip,rk3399-sdhci-5.1",
1272 .compatible = "intel,lgm-sdhci-5.1-emmc",
1276 .compatible = "intel,lgm-sdhci-5.1-sdxc",
1280 .compatible = "intel,keembay-sdhci-5.1-emmc",
1284 .compatible = "intel,keembay-sdhci-5.1-sd",
1288 .compatible = "intel,keembay-sdhci-5.1-sdio",
1292 .compatible = "intel,thunderbay-sdhci-5.1",
1297 .compatible = "arasan,sdhci-8.9a",
1301 .compatible = "arasan,sdhci-5.1",
1305 .compatible = "arasan,sdhci-4.9a",
1309 .compatible = "xlnx,zynqmp-8.9a",
1313 .compatible = "xlnx,versal-8.9a",
1321 * sdhci_arasan_register_sdcardclk - Register the sdcardclk for a PHY to use
1327 * Some PHY devices need to know what the actual card clock is. In order for
1338 struct sdhci_arasan_clk_data *clk_data = &sdhci_arasan->clk_data; in sdhci_arasan_register_sdcardclk()
1339 struct device_node *np = dev->of_node; in sdhci_arasan_register_sdcardclk()
1344 ret = of_property_read_string_index(np, "clock-output-names", 0, in sdhci_arasan_register_sdcardclk()
1347 dev_err(dev, "DT has #clock-cells but no clock-output-names\n"); in sdhci_arasan_register_sdcardclk()
1355 sdcardclk_init.ops = sdhci_arasan->clk_ops->sdcardclk_ops; in sdhci_arasan_register_sdcardclk()
1357 clk_data->sdcardclk_hw.init = &sdcardclk_init; in sdhci_arasan_register_sdcardclk()
1358 clk_data->sdcardclk = in sdhci_arasan_register_sdcardclk()
1359 devm_clk_register(dev, &clk_data->sdcardclk_hw); in sdhci_arasan_register_sdcardclk()
1360 if (IS_ERR(clk_data->sdcardclk)) in sdhci_arasan_register_sdcardclk()
1361 return PTR_ERR(clk_data->sdcardclk); in sdhci_arasan_register_sdcardclk()
1362 clk_data->sdcardclk_hw.init = NULL; in sdhci_arasan_register_sdcardclk()
1365 clk_data->sdcardclk); in sdhci_arasan_register_sdcardclk()
1373 * sdhci_arasan_register_sampleclk - Register the sampleclk for a PHY to use
1379 * Some PHY devices need to know what the actual card clock is. In order for
1390 struct sdhci_arasan_clk_data *clk_data = &sdhci_arasan->clk_data; in sdhci_arasan_register_sampleclk()
1391 struct device_node *np = dev->of_node; in sdhci_arasan_register_sampleclk()
1396 ret = of_property_read_string_index(np, "clock-output-names", 1, in sdhci_arasan_register_sampleclk()
1399 dev_err(dev, "DT has #clock-cells but no clock-output-names\n"); in sdhci_arasan_register_sampleclk()
1407 sampleclk_init.ops = sdhci_arasan->clk_ops->sampleclk_ops; in sdhci_arasan_register_sampleclk()
1409 clk_data->sampleclk_hw.init = &sampleclk_init; in sdhci_arasan_register_sampleclk()
1410 clk_data->sampleclk = in sdhci_arasan_register_sampleclk()
1411 devm_clk_register(dev, &clk_data->sampleclk_hw); in sdhci_arasan_register_sampleclk()
1412 if (IS_ERR(clk_data->sampleclk)) in sdhci_arasan_register_sampleclk()
1413 return PTR_ERR(clk_data->sampleclk); in sdhci_arasan_register_sampleclk()
1414 clk_data->sampleclk_hw.init = NULL; in sdhci_arasan_register_sampleclk()
1417 clk_data->sampleclk); in sdhci_arasan_register_sampleclk()
1425 * sdhci_arasan_unregister_sdclk - Undoes sdhci_arasan_register_sdclk()
1434 struct device_node *np = dev->of_node; in sdhci_arasan_unregister_sdclk()
1436 if (!of_find_property(np, "#clock-cells", NULL)) in sdhci_arasan_unregister_sdclk()
1439 of_clk_del_provider(dev->of_node); in sdhci_arasan_unregister_sdclk()
1443 * sdhci_arasan_update_support64b - Set SUPPORT_64B (64-bit System Bus Support)
1448 * 0: the Core supports only 32-bit System Address Bus.
1449 * 1: the Core supports 64-bit System Address Bus.
1453 * Keem Bay does not support 64-bit access.
1462 soc_ctl_map = sdhci_arasan->soc_ctl_map; in sdhci_arasan_update_support64b()
1467 if (!sdhci_arasan->soc_ctl_base) { in sdhci_arasan_update_support64b()
1468 pr_warn("%s: Have regmap, but no soc-ctl-syscon\n", in sdhci_arasan_update_support64b()
1469 mmc_hostname(host->mmc)); in sdhci_arasan_update_support64b()
1473 sdhci_arasan_syscon_write(host, &soc_ctl_map->support64b, value); in sdhci_arasan_update_support64b()
1477 * sdhci_arasan_register_sdclk - Register the sdcardclk for a PHY to use
1483 * Some PHY devices need to know what the actual card clock is. In order for
1487 * Note: without seriously re-architecting SDHCI's clock code and testing on
1493 * re-architecting SDHCI if we see some benefit to it.
1501 struct device_node *np = dev->of_node; in sdhci_arasan_register_sdclk()
1505 /* Providing a clock to the PHY is optional; no error if missing */ in sdhci_arasan_register_sdclk()
1506 if (of_property_read_u32(np, "#clock-cells", &num_clks) < 0) in sdhci_arasan_register_sdclk()
1527 struct sdhci_host *host = sdhci_arasan->host; in sdhci_arasan_add_host()
1532 if (!sdhci_arasan->has_cqe) in sdhci_arasan_add_host()
1539 cq_host = devm_kzalloc(host->mmc->parent, in sdhci_arasan_add_host()
1542 ret = -ENOMEM; in sdhci_arasan_add_host()
1546 cq_host->mmio = host->ioaddr + SDHCI_ARASAN_CQE_BASE_ADDR; in sdhci_arasan_add_host()
1547 cq_host->ops = &sdhci_arasan_cqhci_ops; in sdhci_arasan_add_host()
1549 dma64 = host->flags & SDHCI_USE_64_BIT_DMA; in sdhci_arasan_add_host()
1551 cq_host->caps |= CQHCI_TASK_DESC_SZ_128; in sdhci_arasan_add_host()
1553 ret = cqhci_init(cq_host, host->mmc, dma64); in sdhci_arasan_add_host()
1575 struct device *dev = &pdev->dev; in sdhci_arasan_probe()
1576 struct device_node *np = dev->of_node; in sdhci_arasan_probe()
1582 return -EINVAL; in sdhci_arasan_probe()
1584 host = sdhci_pltfm_init(pdev, data->pdata, sizeof(*sdhci_arasan)); in sdhci_arasan_probe()
1591 sdhci_arasan->host = host; in sdhci_arasan_probe()
1593 sdhci_arasan->soc_ctl_map = data->soc_ctl_map; in sdhci_arasan_probe()
1594 sdhci_arasan->clk_ops = data->clk_ops; in sdhci_arasan_probe()
1596 node = of_parse_phandle(np, "arasan,soc-ctl-syscon", 0); in sdhci_arasan_probe()
1598 sdhci_arasan->soc_ctl_base = syscon_node_to_regmap(node); in sdhci_arasan_probe()
1601 if (IS_ERR(sdhci_arasan->soc_ctl_base)) { in sdhci_arasan_probe()
1603 PTR_ERR(sdhci_arasan->soc_ctl_base), in sdhci_arasan_probe()
1611 sdhci_arasan->clk_ahb = devm_clk_get(dev, "clk_ahb"); in sdhci_arasan_probe()
1612 if (IS_ERR(sdhci_arasan->clk_ahb)) { in sdhci_arasan_probe()
1613 ret = dev_err_probe(dev, PTR_ERR(sdhci_arasan->clk_ahb), in sdhci_arasan_probe()
1624 ret = clk_prepare_enable(sdhci_arasan->clk_ahb); in sdhci_arasan_probe()
1630 /* If clock-frequency property is set, use the provided value */ in sdhci_arasan_probe()
1631 if (pltfm_host->clock && in sdhci_arasan_probe()
1632 pltfm_host->clock != clk_get_rate(clk_xin)) { in sdhci_arasan_probe()
1633 ret = clk_set_rate(clk_xin, pltfm_host->clock); in sdhci_arasan_probe()
1635 dev_err(&pdev->dev, "Failed to set SD clock rate\n"); in sdhci_arasan_probe()
1646 if (of_property_read_bool(np, "xlnx,fails-without-test-cd")) in sdhci_arasan_probe()
1647 sdhci_arasan->quirks |= SDHCI_ARASAN_QUIRK_FORCE_CDTEST; in sdhci_arasan_probe()
1649 if (of_property_read_bool(np, "xlnx,int-clock-stable-broken")) in sdhci_arasan_probe()
1650 sdhci_arasan->quirks |= SDHCI_ARASAN_QUIRK_CLOCK_UNSTABLE; in sdhci_arasan_probe()
1652 pltfm_host->clk = clk_xin; in sdhci_arasan_probe()
1654 if (of_device_is_compatible(np, "rockchip,rk3399-sdhci-5.1")) in sdhci_arasan_probe()
1657 if (of_device_is_compatible(np, "intel,keembay-sdhci-5.1-emmc") || in sdhci_arasan_probe()
1658 of_device_is_compatible(np, "intel,keembay-sdhci-5.1-sd") || in sdhci_arasan_probe()
1659 of_device_is_compatible(np, "intel,keembay-sdhci-5.1-sdio") || in sdhci_arasan_probe()
1660 of_device_is_compatible(np, "intel,thunderbay-sdhci-5.1")) { in sdhci_arasan_probe()
1664 host->mmc->caps |= MMC_CAP_WAIT_WHILE_BUSY; in sdhci_arasan_probe()
1673 if (of_device_is_compatible(np, "xlnx,zynqmp-8.9a")) { in sdhci_arasan_probe()
1674 host->mmc_host_ops.execute_tuning = in sdhci_arasan_probe()
1677 sdhci_arasan->quirks |= SDHCI_ARASAN_QUIRK_CLOCK_25_BROKEN; in sdhci_arasan_probe()
1678 host->quirks |= SDHCI_QUIRK_MULTIBLOCK_READ_ACMD12; in sdhci_arasan_probe()
1681 arasan_dt_parse_clk_phases(dev, &sdhci_arasan->clk_data); in sdhci_arasan_probe()
1683 ret = mmc_of_parse(host->mmc); in sdhci_arasan_probe()
1689 sdhci_arasan->phy = ERR_PTR(-ENODEV); in sdhci_arasan_probe()
1690 if (of_device_is_compatible(np, "arasan,sdhci-5.1")) { in sdhci_arasan_probe()
1691 sdhci_arasan->phy = devm_phy_get(dev, "phy_arasan"); in sdhci_arasan_probe()
1692 if (IS_ERR(sdhci_arasan->phy)) { in sdhci_arasan_probe()
1693 ret = dev_err_probe(dev, PTR_ERR(sdhci_arasan->phy), in sdhci_arasan_probe()
1694 "No phy for arasan,sdhci-5.1.\n"); in sdhci_arasan_probe()
1698 ret = phy_init(sdhci_arasan->phy); in sdhci_arasan_probe()
1704 host->mmc_host_ops.hs400_enhanced_strobe = in sdhci_arasan_probe()
1706 host->mmc_host_ops.start_signal_voltage_switch = in sdhci_arasan_probe()
1708 sdhci_arasan->has_cqe = true; in sdhci_arasan_probe()
1709 host->mmc->caps2 |= MMC_CAP2_CQE; in sdhci_arasan_probe()
1711 if (!of_property_read_bool(np, "disable-cqe-dcmd")) in sdhci_arasan_probe()
1712 host->mmc->caps2 |= MMC_CAP2_CQE_DCMD; in sdhci_arasan_probe()
1722 if (!IS_ERR(sdhci_arasan->phy)) in sdhci_arasan_probe()
1723 phy_exit(sdhci_arasan->phy); in sdhci_arasan_probe()
1729 clk_disable_unprepare(sdhci_arasan->clk_ahb); in sdhci_arasan_probe()
1740 struct clk *clk_ahb = sdhci_arasan->clk_ahb; in sdhci_arasan_remove()
1742 if (!IS_ERR(sdhci_arasan->phy)) { in sdhci_arasan_remove()
1743 if (sdhci_arasan->is_phy_on) in sdhci_arasan_remove()
1744 phy_power_off(sdhci_arasan->phy); in sdhci_arasan_remove()
1745 phy_exit(sdhci_arasan->phy); in sdhci_arasan_remove()
1748 sdhci_arasan_unregister_sdclk(&pdev->dev); in sdhci_arasan_remove()
1759 .name = "sdhci-arasan",