[PATCH] mmc: atmel_sdhci: re-enable sdhci after SD Card re-insertion
Eugen.Hristev at microchip.com
Eugen.Hristev at microchip.com
Fri Jul 8 14:40:30 CEST 2022
On 6/22/22 4:30 PM, Sergiu Moga wrote:
> Whenever the SD Card would be removed and then re-inserted while in the
> U-Boot command line, the `SDBPWR` bit of the `SDMMC_PCR` register would
> remain unset afterwards. In order for the bit to be set again after
> re-insertion, register an additional `deferred_probe` method that the
> DM would then transparently call. This method will call the generic
> `sdhci_probe` which will, during its execution flow, set this bit to 1.
>
> Signed-off-by: Sergiu Moga <sergiu.moga at microchip.com>
> Reported-by: Mihai Sain <mihai.sain at microchip.com>
> Reviewed-by: Eugen Hristev <eugen.hristev at microchip.com>
> ---
Hi Peng,
To take this patch into my tree I would be happy if you had a look or
reviewed it first.
Thanks,
Eugen
> drivers/mmc/atmel_sdhci.c | 12 ++++++++++++
> 1 file changed, 12 insertions(+)
>
> diff --git a/drivers/mmc/atmel_sdhci.c b/drivers/mmc/atmel_sdhci.c
> index 2b5ceeab94..37b0beeed4 100644
> --- a/drivers/mmc/atmel_sdhci.c
> +++ b/drivers/mmc/atmel_sdhci.c
> @@ -52,6 +52,17 @@ struct atmel_sdhci_plat {
> struct mmc mmc;
> };
>
> +static int atmel_sdhci_deferred_probe(struct sdhci_host *host)
> +{
> + struct udevice *dev = host->mmc->dev;
> +
> + return sdhci_probe(dev);
> +}
> +
> +static const struct sdhci_ops atmel_sdhci_ops = {
> + .deferred_probe = atmel_sdhci_deferred_probe,
> +};
> +
> static int atmel_sdhci_probe(struct udevice *dev)
> {
> struct mmc_uclass_priv *upriv = dev_get_uclass_priv(dev);
> @@ -104,6 +115,7 @@ static int atmel_sdhci_probe(struct udevice *dev)
> return ret;
>
> host->mmc->priv = host;
> + host->ops = &atmel_sdhci_ops;
> upriv->mmc = host->mmc;
>
> clk_free(&clk);
>
More information about the U-Boot
mailing list