Re: [PATCH v3] mmc: limit the number of retries when analyse tuples failed

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Sat, 23 Jan 2021 at 04:32, Fengnan Chang <fengnanchang@xxxxxxxxx> wrote:
>
> when analyse tuples failed, may enter an endless loop,so limit the time of retries.
>
> Signed-off-by: Fengnan Chang <fengnanchang@xxxxxxxxx>

Applied for fixes and by adding a stable tag, thanks!

Kind regards
Uffe


> ---
>  drivers/mmc/core/sdio_cis.c | 6 ++++++
>  1 file changed, 6 insertions(+)
>
> diff --git a/drivers/mmc/core/sdio_cis.c b/drivers/mmc/core/sdio_cis.c
> index dcb3dee59fa5..b8d8b6df9961 100644
> --- a/drivers/mmc/core/sdio_cis.c
> +++ b/drivers/mmc/core/sdio_cis.c
> @@ -24,6 +24,8 @@
>  #include "sdio_cis.h"
>  #include "sdio_ops.h"
>
> +#define SDIO_READ_CIS_TIMEOUT_MS  (10 * 1000) /* 10s */
> +
>  static int cistpl_vers_1(struct mmc_card *card, struct sdio_func *func,
>                          const unsigned char *buf, unsigned size)
>  {
> @@ -266,6 +268,8 @@ static int sdio_read_cis(struct mmc_card *card, struct sdio_func *func)
>
>         do {
>                 unsigned char tpl_code, tpl_link;
> +               unsigned long timeout = jiffies +
> +                       msecs_to_jiffies(SDIO_READ_CIS_TIMEOUT_MS);
>
>                 ret = mmc_io_rw_direct(card, 0, 0, ptr++, 0, &tpl_code);
>                 if (ret)
> @@ -318,6 +322,8 @@ static int sdio_read_cis(struct mmc_card *card, struct sdio_func *func)
>                         prev = &this->next;
>
>                         if (ret == -ENOENT) {
> +                               if (time_after(jiffies, timeout))
> +                                       break;
>                                 /* warn about unknown tuples */
>                                 pr_warn_ratelimited("%s: queuing unknown"
>                                        " CIS tuple 0x%02x (%u bytes)\n",
> --
> 2.25.1
>




[Index of Archives]     [Linux Memonry Technology]     [Linux USB Devel]     [Linux Media]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux