[PATCH] jffs2: Fix serious write stall due to erase

Joakim Tjernlund joakim.tjernlund at transmode.se
Sat Oct 9 12:36:38 EDT 2010


David, pretty please :)

  Jocke
>
> Drop the alloc_sem before erasing flash in
> jffs2_garbage_collect_pass().
> Otherwise writes are put on hold until the erase
> has finised.
>
> Signed-off-by: Joakim Tjernlund <Joakim.Tjernlund at transmode.se>
> ---
>
>  I am fairly sure it is safe to unlock the alloc_sem before
>  calling jffs2_erase_pending_blocks(). Extra confirmation
>  would be great though.
>
>  This problem was introduced in 2.6.35
>
>  fs/jffs2/gc.c |    7 ++++---
>  1 files changed, 4 insertions(+), 3 deletions(-)
>
> diff --git a/fs/jffs2/gc.c b/fs/jffs2/gc.c
> index f5e96bd..b5f7175 100644
> --- a/fs/jffs2/gc.c
> +++ b/fs/jffs2/gc.c
> @@ -218,13 +218,14 @@ int jffs2_garbage_collect_pass(struct jffs2_sb_info *c)
>     if (!list_empty(&c->erase_complete_list) ||
>         !list_empty(&c->erase_pending_list)) {
>        spin_unlock(&c->erase_completion_lock);
> +      mutex_unlock(&c->alloc_sem);
>        D1(printk(KERN_DEBUG "jffs2_garbage_collect_pass() erasing pending blocks\n"));
> -      if (jffs2_erase_pending_blocks(c, 1)) {
> -         mutex_unlock(&c->alloc_sem);
> +      if (jffs2_erase_pending_blocks(c, 1))
>           return 0;
> -      }
> +
>        D1(printk(KERN_DEBUG "No progress from erasing blocks; doing GC anyway\n"));
>        spin_lock(&c->erase_completion_lock);
> +      mutex_lock(&c->alloc_sem);
>     }
>
>     /* First, work out which block we're garbage-collecting */
> --
> 1.7.2.2
>
>
> ______________________________________________________
> Linux MTD discussion mailing list
> http://lists.infradead.org/mailman/listinfo/linux-mtd/




More information about the linux-mtd mailing list