diff options
| -rw-r--r-- | drivers/spi/spi-bitbang.c | 17 |
1 files changed, 10 insertions, 7 deletions
diff --git a/drivers/spi/spi-bitbang.c b/drivers/spi/spi-bitbang.c index 5ef6638d5e8a..840a4984d365 100644 --- a/drivers/spi/spi-bitbang.c +++ b/drivers/spi/spi-bitbang.c | |||
| @@ -180,7 +180,6 @@ int spi_bitbang_setup(struct spi_device *spi) | |||
| 180 | { | 180 | { |
| 181 | struct spi_bitbang_cs *cs = spi->controller_state; | 181 | struct spi_bitbang_cs *cs = spi->controller_state; |
| 182 | struct spi_bitbang *bitbang; | 182 | struct spi_bitbang *bitbang; |
| 183 | int retval; | ||
| 184 | unsigned long flags; | 183 | unsigned long flags; |
| 185 | 184 | ||
| 186 | bitbang = spi_master_get_devdata(spi->master); | 185 | bitbang = spi_master_get_devdata(spi->master); |
| @@ -197,9 +196,11 @@ int spi_bitbang_setup(struct spi_device *spi) | |||
| 197 | if (!cs->txrx_word) | 196 | if (!cs->txrx_word) |
| 198 | return -EINVAL; | 197 | return -EINVAL; |
| 199 | 198 | ||
| 200 | retval = bitbang->setup_transfer(spi, NULL); | 199 | if (bitbang->setup_transfer) { |
| 201 | if (retval < 0) | 200 | int retval = bitbang->setup_transfer(spi, NULL); |
| 202 | return retval; | 201 | if (retval < 0) |
| 202 | return retval; | ||
| 203 | } | ||
| 203 | 204 | ||
| 204 | dev_dbg(&spi->dev, "%s, %u nsec/bit\n", __func__, 2 * cs->nsecs); | 205 | dev_dbg(&spi->dev, "%s, %u nsec/bit\n", __func__, 2 * cs->nsecs); |
| 205 | 206 | ||
| @@ -295,9 +296,11 @@ static int spi_bitbang_transfer_one(struct spi_master *master, | |||
| 295 | 296 | ||
| 296 | /* init (-1) or override (1) transfer params */ | 297 | /* init (-1) or override (1) transfer params */ |
| 297 | if (do_setup != 0) { | 298 | if (do_setup != 0) { |
| 298 | status = bitbang->setup_transfer(spi, t); | 299 | if (bitbang->setup_transfer) { |
| 299 | if (status < 0) | 300 | status = bitbang->setup_transfer(spi, t); |
| 300 | break; | 301 | if (status < 0) |
| 302 | break; | ||
| 303 | } | ||
| 301 | if (do_setup == -1) | 304 | if (do_setup == -1) |
| 302 | do_setup = 0; | 305 | do_setup = 0; |
| 303 | } | 306 | } |
