[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <OFB51E93AB.187F855F-ONC12576D2.00618F62-C12576D2.0061DEB5@transmode.se>
Date: Mon, 22 Feb 2010 18:49:00 +0100
From: Joakim Tjernlund <joakim.tjernlund@...nsmode.se>
To: niam <niam.niam@...il.com>
Cc: David Woodhouse <dwmw2@...radead.org>,
Joe Perches <joe@...ches.com>, linux-kernel@...r.kernel.org,
linux-mtd@...ts.infradead.org
Subject: Re: [PATCH] jffs2: fix memory leak if the sector was successfully erased
niam <niam.niam@...il.com> wrote on 2010/02/22 17:40:11:
>
> Resending patch to proper people/mailing list.
>
> Memory allocated for erase instruction is not freed if the sector was
> successfully erased.
NAK, jffs2_erase_callback() will free it so
you have added a double free I think. Did you measure a memory leak?
>
> Signed-off-by: Dmytro Milinevskyy <niam.niam@...il.com>
> ---
> fs/jffs2/erase.c | 4 +++-
> 1 files changed, 3 insertions(+), 1 deletions(-)
>
> diff --git a/fs/jffs2/erase.c b/fs/jffs2/erase.c
> index b47679b..c0a5604 100644
> --- a/fs/jffs2/erase.c
> +++ b/fs/jffs2/erase.c
> @@ -74,8 +74,10 @@ static void jffs2_erase_block(struct jffs2_sb_info *c,
> ((struct erase_priv_struct *)instr->priv)->c = c;
>
> ret = c->mtd->erase(c->mtd, instr);
> - if (!ret)
> + if (!ret) {
> + kfree(instr);
> return;
> + }
>
> bad_offset = instr->fail_addr;
> kfree(instr);
>
--
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