Skip to content

Commit 1c6286f

Browse files
Dan Carpenteraxboe
authored andcommitted
lightnvm: fix some error code in pblk-init.c
There were a bunch of places in pblk_lines_init() where we didn't set an error code. And in pblk_writer_init() we accidentally return 1 instead of a correct error code, which would result in a Oops later. Fixes: 11a5d6fdf919 ("lightnvm: physical block device (pblk) target") Signed-off-by: Dan Carpenter <[email protected]> Signed-off-by: Matias Bjørling <[email protected]> Signed-off-by: Jens Axboe <[email protected]>
1 parent 2a79efd commit 1c6286f

File tree

1 file changed

+14
-6
lines changed

1 file changed

+14
-6
lines changed

drivers/lightnvm/pblk-init.c

Lines changed: 14 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -543,7 +543,7 @@ static int pblk_lines_init(struct pblk *pblk)
543543
long nr_bad_blks, nr_meta_blks, nr_free_blks;
544544
int bb_distance;
545545
int i;
546-
int ret = 0;
546+
int ret;
547547

548548
lm->sec_per_line = geo->sec_per_blk * geo->nr_luns;
549549
lm->blk_per_line = geo->nr_luns;
@@ -638,12 +638,16 @@ static int pblk_lines_init(struct pblk *pblk)
638638
}
639639

640640
l_mg->bb_template = kzalloc(lm->sec_bitmap_len, GFP_KERNEL);
641-
if (!l_mg->bb_template)
641+
if (!l_mg->bb_template) {
642+
ret = -ENOMEM;
642643
goto fail_free_meta;
644+
}
643645

644646
l_mg->bb_aux = kzalloc(lm->sec_bitmap_len, GFP_KERNEL);
645-
if (!l_mg->bb_aux)
647+
if (!l_mg->bb_aux) {
648+
ret = -ENOMEM;
646649
goto fail_free_bb_template;
650+
}
647651

648652
bb_distance = (geo->nr_luns) * geo->sec_per_pl;
649653
for (i = 0; i < lm->sec_per_line; i += bb_distance)
@@ -667,8 +671,10 @@ static int pblk_lines_init(struct pblk *pblk)
667671

668672
pblk->lines = kcalloc(l_mg->nr_lines, sizeof(struct pblk_line),
669673
GFP_KERNEL);
670-
if (!pblk->lines)
674+
if (!pblk->lines) {
675+
ret = -ENOMEM;
671676
goto fail_free_bb_aux;
677+
}
672678

673679
nr_free_blks = 0;
674680
for (i = 0; i < l_mg->nr_lines; i++) {
@@ -682,8 +688,10 @@ static int pblk_lines_init(struct pblk *pblk)
682688
spin_lock_init(&line->lock);
683689

684690
nr_bad_blks = pblk_bb_line(pblk, line);
685-
if (nr_bad_blks < 0 || nr_bad_blks > lm->blk_per_line)
691+
if (nr_bad_blks < 0 || nr_bad_blks > lm->blk_per_line) {
692+
ret = -EINVAL;
686693
goto fail_free_lines;
694+
}
687695

688696
line->blk_in_line = lm->blk_per_line - nr_bad_blks;
689697
if (line->blk_in_line < lm->min_blk_line) {
@@ -733,7 +741,7 @@ static int pblk_writer_init(struct pblk *pblk)
733741
pblk->writer_ts = kthread_create(pblk_write_ts, pblk, "pblk-writer-t");
734742
if (IS_ERR(pblk->writer_ts)) {
735743
pr_err("pblk: could not allocate writer kthread\n");
736-
return 1;
744+
return PTR_ERR(pblk->writer_ts);
737745
}
738746

739747
return 0;

0 commit comments

Comments
 (0)