[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <20090415161041.10d1aa71.akpm@linux-foundation.org>
Date: Wed, 15 Apr 2009 16:10:41 -0700
From: Andrew Morton <akpm@...ux-foundation.org>
To: Peter Horton <zero@...onel-panic.org>
Cc: linux-mtd@...ts.infradead.org, linux-kernel@...r.kernel.org,
dwmw2@...radead.org
Subject: Re: [PATCH] mtd: fix timeout in M25P80 driver
On Mon, 13 Apr 2009 15:26:33 +0100
Peter Horton <zero@...onel-panic.org> wrote:
> Extend erase timeout in M25P80 SPI Flash driver.
>
> The M25P80 drivers fails erasing sectors on a M25P128 because the ready
> wait timeout is too short. Change the timeout from a simple loop count to a
> suitable number of seconds.
>
> Signed-off-by: Peter Horton <zero@...onel-panic.org>
> ---
> Index: linux-2.6.29-git12/drivers/mtd/devices/m25p80.c
> ===================================================================
> --- linux-2.6.29-git12.orig/drivers/mtd/devices/m25p80.c 2009-04-12 21:41:16.000000000 +0000
> +++ linux-2.6.29-git12/drivers/mtd/devices/m25p80.c 2009-04-12 21:43:01.000000000 +0000
> @@ -54,7 +54,7 @@
> #define SR_SRWD 0x80 /* SR write protect */
>
> /* Define max times to check status register before we give up. */
> -#define MAX_READY_WAIT_COUNT 100000
> +#define MAX_READY_WAIT_JIFFIES (10 * HZ) /* eg. M25P128 specs 6s max sector erase */
> #define CMD_SIZE 4
>
> #ifdef CONFIG_M25PXX_USE_FAST_READ
> @@ -145,20 +145,20 @@
> */
> static int wait_till_ready(struct m25p *flash)
> {
> - int count;
> + unsigned long deadline;
> int sr;
>
> - /* one chip guarantees max 5 msec wait here after page writes,
> - * but potentially three seconds (!) after page erase.
> - */
> - for (count = 0; count < MAX_READY_WAIT_COUNT; count++) {
> + deadline = jiffies + MAX_READY_WAIT_JIFFIES;
> +
> + do {
> if ((sr = read_sr(flash)) < 0)
> break;
> else if (!(sr & SR_WIP))
> return 0;
>
> - /* REVISIT sometimes sleeping would be best */
> - }
> + cond_resched();
> +
> + } while (!time_after_eq(jiffies, deadline));
>
> return 1;
ow, so it sits there chewing electricity for up to ten seconds.
How much time does this really take, in the real world?
It would be better to fall back to (say) msleep(1) if we find out that
the device is being slow to respond.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists