Skip to content

Commit 31ed8eb

Browse files
andy-shevbroonie
authored andcommitted
spi: Make error handling of gpiod_count() call cleaner
Each time we call spi_get_gpio_descs() the num_chipselect is overwritten either by new value or by the old one. This is an extra operation in case gpiod_count() returns an error. Besides that it slashes the error handling of gpiod_count(). Refactor the code to make error handling of gpiod_count() call cleaner. Note, that gpiod_count() never returns 0, take this into account as well. Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com> Link: https://lore.kernel.org/r/20210420164040.40055-1-andriy.shevchenko@linux.intel.com Signed-off-by: Mark Brown <broonie@kernel.org>
1 parent 1799bb1 commit 31ed8eb

1 file changed

Lines changed: 7 additions & 6 deletions

File tree

drivers/spi/spi.c

Lines changed: 7 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -2551,13 +2551,14 @@ static int spi_get_gpio_descs(struct spi_controller *ctlr)
25512551
unsigned int num_cs_gpios = 0;
25522552

25532553
nb = gpiod_count(dev, "cs");
2554-
ctlr->num_chipselect = max_t(int, nb, ctlr->num_chipselect);
2555-
2556-
/* No GPIOs at all is fine, else return the error */
2557-
if (nb == 0 || nb == -ENOENT)
2558-
return 0;
2559-
else if (nb < 0)
2554+
if (nb < 0) {
2555+
/* No GPIOs at all is fine, else return the error */
2556+
if (nb == -ENOENT)
2557+
return 0;
25602558
return nb;
2559+
}
2560+
2561+
ctlr->num_chipselect = max_t(int, nb, ctlr->num_chipselect);
25612562

25622563
cs = devm_kcalloc(dev, ctlr->num_chipselect, sizeof(*cs),
25632564
GFP_KERNEL);

0 commit comments

Comments
 (0)