[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <7960b012-1154-fdad-0c45-c952357f13f5@virtuozzo.com>
Date: Fri, 6 Oct 2017 12:20:56 +0300
From: Andrey Ryabinin <aryabinin@...tuozzo.com>
To: Hans Holmberg <hans.ml.holmberg@...tronix.com>,
Matias Bjorling <mb@...htnvm.io>
Cc: linux-block@...r.kernel.org, linux-kernel@...r.kernel.org,
Javier Gonzales <jg@...htnvm.io>,
Hans Holmberg <hans.holmberg@...xlabs.com>
Subject: Re: [PATCH] lightnvm: pblk: remove spinlock when freeing line
metadata
On 10/05/2017 11:35 AM, Hans Holmberg wrote:
> From: Hans Holmberg <hans.holmberg@...xlabs.com>
>
> Lockdep complains about being in atomic context while freeing line
> metadata - and rightly so as we take a spinlock and end up calling
> vfree that might sleep(in pblk_mfree).
>
> There is no need for holding the line manager free_lock while
> freeing line metadata, so remove the lock.
>
> Signed-off-by: Hans Holmberg <hans.holmberg@...xlabs.com>
Reviewed-by: Andrey Ryabinin <aryabinin@...tuozzo.com>
I guess this also deserves stable tag. The bug was introduced in 4.13 by
commit 588726d3ec68 ("lightnvm: pblk: fail gracefully on irrec. error").
> ---
> This patch is for:
> https://github.com/OpenChannelSSD/linux branch for-4.15/pblk
>
> drivers/lightnvm/pblk-init.c | 2 --
> 1 file changed, 2 deletions(-)
>
> diff --git a/drivers/lightnvm/pblk-init.c b/drivers/lightnvm/pblk-init.c
> index c452478..a645117 100644
> --- a/drivers/lightnvm/pblk-init.c
> +++ b/drivers/lightnvm/pblk-init.c
> @@ -393,13 +393,11 @@ static void pblk_line_meta_free(struct pblk *pblk)
> kfree(l_mg->bb_aux);
> kfree(l_mg->vsc_list);
>
> - spin_lock(&l_mg->free_lock);
> for (i = 0; i < PBLK_DATA_LINES; i++) {
> kfree(l_mg->sline_meta[i]);
> pblk_mfree(l_mg->eline_meta[i]->buf, l_mg->emeta_alloc_type);
> kfree(l_mg->eline_meta[i]);
> }
> - spin_unlock(&l_mg->free_lock);
>
> kfree(pblk->lines);
> }
>
Powered by blists - more mailing lists