aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/md/dm-mpath.c22
1 files changed, 12 insertions, 10 deletions
diff --git a/drivers/md/dm-mpath.c b/drivers/md/dm-mpath.c
index c2fcf28b4c70..c2ff77d77a5e 100644
--- a/drivers/md/dm-mpath.c
+++ b/drivers/md/dm-mpath.c
@@ -563,12 +563,12 @@ static struct pgpath *parse_path(struct arg_set *as, struct path_selector *ps,
563 /* we need at least a path arg */ 563 /* we need at least a path arg */
564 if (as->argc < 1) { 564 if (as->argc < 1) {
565 ti->error = "no device given"; 565 ti->error = "no device given";
566 return NULL; 566 return ERR_PTR(-EINVAL);
567 } 567 }
568 568
569 p = alloc_pgpath(); 569 p = alloc_pgpath();
570 if (!p) 570 if (!p)
571 return NULL; 571 return ERR_PTR(-ENOMEM);
572 572
573 r = dm_get_device(ti, shift(as), ti->begin, ti->len, 573 r = dm_get_device(ti, shift(as), ti->begin, ti->len,
574 dm_table_get_mode(ti->table), &p->path.dev); 574 dm_table_get_mode(ti->table), &p->path.dev);
@@ -596,7 +596,7 @@ static struct pgpath *parse_path(struct arg_set *as, struct path_selector *ps,
596 596
597 bad: 597 bad:
598 free_pgpath(p); 598 free_pgpath(p);
599 return NULL; 599 return ERR_PTR(r);
600} 600}
601 601
602static struct priority_group *parse_priority_group(struct arg_set *as, 602static struct priority_group *parse_priority_group(struct arg_set *as,
@@ -614,14 +614,14 @@ static struct priority_group *parse_priority_group(struct arg_set *as,
614 614
615 if (as->argc < 2) { 615 if (as->argc < 2) {
616 as->argc = 0; 616 as->argc = 0;
617 ti->error = "not enough priority group aruments"; 617 ti->error = "not enough priority group arguments";
618 return NULL; 618 return ERR_PTR(-EINVAL);
619 } 619 }
620 620
621 pg = alloc_priority_group(); 621 pg = alloc_priority_group();
622 if (!pg) { 622 if (!pg) {
623 ti->error = "couldn't allocate priority group"; 623 ti->error = "couldn't allocate priority group";
624 return NULL; 624 return ERR_PTR(-ENOMEM);
625 } 625 }
626 pg->m = m; 626 pg->m = m;
627 627
@@ -654,8 +654,10 @@ static struct priority_group *parse_priority_group(struct arg_set *as,
654 path_args.argv = as->argv; 654 path_args.argv = as->argv;
655 655
656 pgpath = parse_path(&path_args, &pg->ps, ti); 656 pgpath = parse_path(&path_args, &pg->ps, ti);
657 if (!pgpath) 657 if (IS_ERR(pgpath)) {
658 r = PTR_ERR(pgpath);
658 goto bad; 659 goto bad;
660 }
659 661
660 pgpath->pg = pg; 662 pgpath->pg = pg;
661 list_add_tail(&pgpath->list, &pg->pgpaths); 663 list_add_tail(&pgpath->list, &pg->pgpaths);
@@ -666,7 +668,7 @@ static struct priority_group *parse_priority_group(struct arg_set *as,
666 668
667 bad: 669 bad:
668 free_priority_group(pg, ti); 670 free_priority_group(pg, ti);
669 return NULL; 671 return ERR_PTR(r);
670} 672}
671 673
672static int parse_hw_handler(struct arg_set *as, struct multipath *m) 674static int parse_hw_handler(struct arg_set *as, struct multipath *m)
@@ -785,8 +787,8 @@ static int multipath_ctr(struct dm_target *ti, unsigned int argc,
785 struct priority_group *pg; 787 struct priority_group *pg;
786 788
787 pg = parse_priority_group(&as, m); 789 pg = parse_priority_group(&as, m);
788 if (!pg) { 790 if (IS_ERR(pg)) {
789 r = -EINVAL; 791 r = PTR_ERR(pg);
790 goto bad; 792 goto bad;
791 } 793 }
792 794