Lines Matching +full:reset +full:- +full:delay +full:- +full:us

1 // SPDX-License-Identifier: GPL-2.0-or-later
3 * drivers/mmc/host/sdhci-of-sparx5.c
13 #include <linux/delay.h>
18 #include <linux/dma-mapping.h>
20 #include "sdhci-pltfm.h"
46 ((addr | (SZ_128M - 1)) == ((addr + len - 1) | (SZ_128M - 1)))
64 mmc_hostname(host->mmc), len, &addr); in sdhci_sparx5_adma_write_desc()
66 offset = addr & (SZ_128M - 1); in sdhci_sparx5_adma_write_desc()
67 tmplen = SZ_128M - offset; in sdhci_sparx5_adma_write_desc()
71 len -= tmplen; in sdhci_sparx5_adma_write_desc()
80 pr_debug("%s: Set Cacheable = 0x%x\n", mmc_hostname(host->mmc), value); in sparx5_set_cacheable()
83 regmap_update_bits(sdhci_sparx5->cpu_ctrl, in sparx5_set_cacheable()
92 pr_debug("%s: Set DLY_CC = %u\n", mmc_hostname(host->mmc), value); in sparx5_set_delay()
95 regmap_update_bits(sdhci_sparx5->cpu_ctrl, in sparx5_set_delay()
103 if (!mmc_card_is_removable(host->mmc)) { in sdhci_sparx5_set_emmc()
110 mmc_hostname(host->mmc), value); in sdhci_sparx5_set_emmc()
120 pr_debug("%s: Toggle EMMC_CTRL.EMMC_RST_N\n", mmc_hostname(host->mmc)); in sdhci_sparx5_reset_emmc()
124 /* For eMMC, minimum is 1us but give it 10us for good measure */ in sdhci_sparx5_reset_emmc()
128 /* For eMMC, minimum is 200us but give it 300us for good measure */ in sdhci_sparx5_reset_emmc()
134 pr_debug("%s: *** RESET: mask %d\n", mmc_hostname(host->mmc), mask); in sdhci_sparx5_reset()
147 .reset = sdhci_sparx5_reset,
161 const char *syscon = "microchip,sparx5-cpu-syscon"; in sdhci_sparx5_probe()
165 struct device_node *np = pdev->dev.of_node; in sdhci_sparx5_probe()
178 extra = DIV_ROUND_UP_ULL(dma_get_required_mask(&pdev->dev), SZ_128M); in sdhci_sparx5_probe()
181 host->adma_table_cnt += extra; in sdhci_sparx5_probe()
185 sdhci_sparx5->host = host; in sdhci_sparx5_probe()
187 pltfm_host->clk = devm_clk_get(&pdev->dev, "core"); in sdhci_sparx5_probe()
188 if (IS_ERR(pltfm_host->clk)) { in sdhci_sparx5_probe()
189 ret = PTR_ERR(pltfm_host->clk); in sdhci_sparx5_probe()
190 dev_err(&pdev->dev, "failed to get core clk: %d\n", ret); in sdhci_sparx5_probe()
193 ret = clk_prepare_enable(pltfm_host->clk); in sdhci_sparx5_probe()
197 if (!of_property_read_u32(np, "microchip,clock-delay", &value) && in sdhci_sparx5_probe()
199 sdhci_sparx5->delay_clock = value; in sdhci_sparx5_probe()
203 ret = mmc_of_parse(host->mmc); in sdhci_sparx5_probe()
207 sdhci_sparx5->cpu_ctrl = syscon_regmap_lookup_by_compatible(syscon); in sdhci_sparx5_probe()
208 if (IS_ERR(sdhci_sparx5->cpu_ctrl)) { in sdhci_sparx5_probe()
209 dev_err(&pdev->dev, "No CPU syscon regmap !\n"); in sdhci_sparx5_probe()
210 ret = PTR_ERR(sdhci_sparx5->cpu_ctrl); in sdhci_sparx5_probe()
214 if (sdhci_sparx5->delay_clock >= 0) in sdhci_sparx5_probe()
215 sparx5_set_delay(host, sdhci_sparx5->delay_clock); in sdhci_sparx5_probe()
217 if (!mmc_card_is_removable(host->mmc)) { in sdhci_sparx5_probe()
218 /* Do a HW reset of eMMC card */ in sdhci_sparx5_probe()
223 host->mmc->caps2 |= (MMC_CAP2_NO_SDIO|MMC_CAP2_NO_SD); in sdhci_sparx5_probe()
230 /* Set AXI bus master to use un-cached access (for DMA) */ in sdhci_sparx5_probe()
231 if (host->flags & (SDHCI_USE_SDMA | SDHCI_USE_ADMA) && in sdhci_sparx5_probe()
236 mmc_hostname(host->mmc), sdhci_readl(host, MSHC2_VERSION)); in sdhci_sparx5_probe()
238 mmc_hostname(host->mmc), sdhci_readl(host, MSHC2_TYPE)); in sdhci_sparx5_probe()
243 clk_disable_unprepare(pltfm_host->clk); in sdhci_sparx5_probe()
250 { .compatible = "microchip,dw-sparx5-sdhci" },
257 .name = "sdhci-sparx5",