[PATCH v2] mtd: onenand: fix deadlock in onenand_block_markbad
Artem Bityutskiy
artem.bityutskiy at linux.intel.com
Wed Feb 24 03:59:56 PST 2016
Looks good, thanks!
Acked-by: Artem Bityutskiy <artem.bityutskiy at linux.intel.com>
On Sat, 2016-02-20 at 22:27 +0200, Aaro Koskinen wrote:
> Commit 5942ddbc500d ("mtd: introduce mtd_block_markbad interface")
> incorrectly changed onenand_block_markbad() to call mtd_block_markbad
> instead of onenand_chip's block_markbad function. As a result the
> function
> will now recurse and deadlock. Fix by reverting the change.
>
> Fixes: 5942ddbc500d ("mtd: introduce mtd_block_markbad interface")
> Signed-off-by: Aaro Koskinen <aaro.koskinen at iki.fi>
> ---
>
> v2: Don't ignore the return value.
>
> v1: http://lists.infradead.org/pipermail/linux-mtd/2016-Februar
> y/065582.html
>
> drivers/mtd/onenand/onenand_base.c | 3 ++-
> 1 file changed, 2 insertions(+), 1 deletion(-)
>
> diff --git a/drivers/mtd/onenand/onenand_base.c
> b/drivers/mtd/onenand/onenand_base.c
> index 43b3392..652d018 100644
> --- a/drivers/mtd/onenand/onenand_base.c
> +++ b/drivers/mtd/onenand/onenand_base.c
> @@ -2599,6 +2599,7 @@ static int onenand_default_block_markbad(struct
> mtd_info *mtd, loff_t ofs)
> */
> static int onenand_block_markbad(struct mtd_info *mtd, loff_t ofs)
> {
> + struct onenand_chip *this = mtd->priv;
> int ret;
>
> ret = onenand_block_isbad(mtd, ofs);
> @@ -2610,7 +2611,7 @@ static int onenand_block_markbad(struct
> mtd_info *mtd, loff_t ofs)
> }
>
> onenand_get_device(mtd, FL_WRITING);
> - ret = mtd_block_markbad(mtd, ofs);
> + ret = this->block_markbad(mtd, ofs);
> onenand_release_device(mtd);
> return ret;
> }
--
Best Regards,
Artem Bityutskiy
More information about the linux-mtd
mailing list