[U-Boot] [PATCH v2 4/4] mmc: sdhci: add the udelay for completed post-request

Andy Fleming afleming at gmail.com
Thu Aug 30 23:55:09 CEST 2012


On Thu, Jul 26, 2012 at 7:33 PM, Jaehoon Chung <jh80.chung at samsung.com> wrote:
> To ensure that complete the request, add udelay(100).
> Also  increased the timeout value to 10000.
> (Because timeout value is short, there is the case that didn't transfer data)
>
> Signed-off-by: Jaehoon Chung <jh80.chung at samsung.com>
> ---
>  drivers/mmc/sdhci.c |    3 ++-
>  1 files changed, 2 insertions(+), 1 deletions(-)
>
> diff --git a/drivers/mmc/sdhci.c b/drivers/mmc/sdhci.c
> index ac39e48..f71a14b 100644
> --- a/drivers/mmc/sdhci.c
> +++ b/drivers/mmc/sdhci.c
> @@ -83,7 +83,7 @@ static int sdhci_transfer_data(struct sdhci_host *host, struct mmc_data *data,
>  {
>         unsigned int stat, rdy, mask, timeout, block = 0;
>
> -       timeout = 10000;
> +       timeout = 100000;
>         rdy = SDHCI_INT_SPACE_AVAIL | SDHCI_INT_DATA_AVAIL;
>         mask = SDHCI_DATA_AVAILABLE | SDHCI_SPACE_AVAILABLE;
>         do {
> @@ -239,6 +239,7 @@ int sdhci_send_command(struct mmc *mmc, struct mmc_cmd *cmd,
>                 if ((host->quirks & SDHCI_QUIRK_32BIT_DMA_ADDR) &&
>                                 !is_aligned && (data->flags == MMC_DATA_READ))
>                         memcpy(data->dest, aligned_buffer, trans_bytes);
> +               udelay(100);


These sorts of changes (both the increased timeout, and the udelay)
look very much like attempting to use time to substitute for proper
coherency assurances. What "request" is this udelay allowing to
finish?

Andy


More information about the U-Boot mailing list