From: Dan Carpenter Date: Fri, 1 Oct 2021 12:26:54 +0000 (+0300) Subject: pf: fix error codes in pf_init_unit() X-Git-Tag: v6.1-rc5~2682^2~87 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=cfc03eabda8224c681087a4c6c51d1cc595ebfaf;p=platform%2Fkernel%2Flinux-starfive.git pf: fix error codes in pf_init_unit() Return a negative error code instead of success on these error paths. Fixes: fb367e6baeb0 ("pf: cleanup initialization") Signed-off-by: Dan Carpenter Link: https://lore.kernel.org/r/20211001122654.GB2283@kili Signed-off-by: Jens Axboe --- diff --git a/drivers/block/paride/pf.c b/drivers/block/paride/pf.c index 380d80e..bf8d0ef 100644 --- a/drivers/block/paride/pf.c +++ b/drivers/block/paride/pf.c @@ -651,9 +651,9 @@ static int pf_identify(struct pf_unit *pf) return 0; } -/* returns 0, with id set if drive is detected - -1, if drive detection failed -*/ +/* + * returns 0, with id set if drive is detected, otherwise an error code. + */ static int pf_probe(struct pf_unit *pf) { if (pf->drive == -1) { @@ -675,7 +675,7 @@ static int pf_probe(struct pf_unit *pf) if (!pf_identify(pf)) return 0; } - return -1; + return -ENODEV; } /* The i/o request engine */ @@ -957,9 +957,12 @@ static int __init pf_init_unit(struct pf_unit *pf, bool autoprobe, int port, snprintf(pf->name, PF_NAMELEN, "%s%d", name, disk->first_minor); if (!pi_init(pf->pi, autoprobe, port, mode, unit, protocol, delay, - pf_scratch, PI_PF, verbose, pf->name)) + pf_scratch, PI_PF, verbose, pf->name)) { + ret = -ENODEV; goto out_free_disk; - if (pf_probe(pf)) + } + ret = pf_probe(pf); + if (ret) goto out_pi_release; ret = add_disk(disk);