Commit 2cfb8ce8 authored by Jan Nikitenko's avatar Jan Nikitenko Committed by Linus Torvalds

spi_bitbang: short transfer status fix

SPI controller drivers return number of bytes actually transfered from
bitbang->txrx_bufs() method.  This updates handling of short transfers (where
the transfer size is less than requested):

 - Even zero byte short transfers should report errors;
 - Include short transfers in the total of transferred bytes;
 - Use EREMOTEIO (like USB) not EMSGSIZE to report short transfers

Short transfers don't normally mean invalid message sizes, but if the
underlying controller driver needs to use EMSGSIZE it can still do so.

[db: fix two more minor issues]
Signed-off-by: default avatarJan Nikitenko <jan.nikitenko@gmail.com>
Signed-off-by: default avatarDavid Brownell <dbrownell@users.sourceforge.net>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 40369e1c
...@@ -344,12 +344,14 @@ static void bitbang_work(struct work_struct *work) ...@@ -344,12 +344,14 @@ static void bitbang_work(struct work_struct *work)
t->rx_dma = t->tx_dma = 0; t->rx_dma = t->tx_dma = 0;
status = bitbang->txrx_bufs(spi, t); status = bitbang->txrx_bufs(spi, t);
} }
if (status != t->len) {
if (status > 0) if (status > 0)
status = -EMSGSIZE; m->actual_length += status;
if (status != t->len) {
/* always report some kind of error */
if (status >= 0)
status = -EREMOTEIO;
break; break;
} }
m->actual_length += status;
status = 0; status = 0;
/* protocol tweaks before next transfer */ /* protocol tweaks before next transfer */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment