From: "Matias Bjørling" <mb@lightnvm.io>
To: Wenwei Tao <ww.tao0320@gmail.com>
Cc: linux-kernel@vger.kernel.org, linux-block@vger.kernel.org
Subject: Re: [PATCH] lightnvm: put blks when luns configure failed
Date: Fri, 4 Dec 2015 13:21:58 +0100 [thread overview]
Message-ID: <56618566.30809@lightnvm.io> (raw)
In-Reply-To: <1449149248-3336-1-git-send-email-ww.tao0320@gmail.com>
On 12/03/2015 02:27 PM, Wenwei Tao wrote:
> put the allocated blks back to the free list
> when the luns configure failed, to make these
> blks useable to others.
>
> Signed-off-by: Wenwei Tao <ww.tao0320@gmail.com>
> ---
> drivers/lightnvm/rrpc.c | 21 +++++++++++++++++++--
> 1 file changed, 19 insertions(+), 2 deletions(-)
>
> diff --git a/drivers/lightnvm/rrpc.c b/drivers/lightnvm/rrpc.c
> index 75e59c3..1bb2f97 100644
> --- a/drivers/lightnvm/rrpc.c
> +++ b/drivers/lightnvm/rrpc.c
> @@ -202,6 +202,20 @@ static void rrpc_put_blk(struct rrpc *rrpc, struct rrpc_block *rblk)
> nvm_put_blk(rrpc->dev, rblk->parent);
> }
>
> +static void rrpc_put_blks(struct rrpc *rrpc)
> +{
> + struct rrpc_lun *rlun;
> + int i;
> +
> + for (i = 0; i < rrpc->nr_luns; i++) {
> + rlun = &rrpc->luns[i];
> + if (rlun->cur)
> + rrpc_put_blk(rrpc, rlun->cur);
> + if (rlun->gc_cur)
> + rrpc_put_blk(rrpc, rlun->gc_cur);
> + }
> +}
> +
> static struct rrpc_lun *get_next_lun(struct rrpc *rrpc)
> {
> int next = atomic_inc_return(&rrpc->next_lun);
> @@ -1224,18 +1238,21 @@ static int rrpc_luns_configure(struct rrpc *rrpc)
>
> rblk = rrpc_get_blk(rrpc, rlun, 0);
> if (!rblk)
> - return -EINVAL;
> + goto err;
>
> rrpc_set_lun_cur(rlun, rblk);
>
> /* Emergency gc block */
> rblk = rrpc_get_blk(rrpc, rlun, 1);
> if (!rblk)
> - return -EINVAL;
> + goto err;
> rlun->gc_cur = rblk;
> }
>
> return 0;
> +err:
> + rrpc_put_blks(rrpc);
> + return -EINVAL;
> }
>
> static struct nvm_tgt_type tt_rrpc;
>
Thanks Tao, applied.
prev parent reply other threads:[~2015-12-04 12:22 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-12-03 13:27 [PATCH] lightnvm: put blks when luns configure failed Wenwei Tao
2015-12-04 12:21 ` Matias Bjørling [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=56618566.30809@lightnvm.io \
--to=mb@lightnvm.io \
--cc=linux-block@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=ww.tao0320@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.