diff options
author | Chris Lesiak <[email protected]> | 2019-03-07 20:39:00 +0000 |
---|---|---|
committer | Mark Brown <[email protected]> | 2019-03-11 16:40:00 +0000 |
commit | 5442dcaa0d90fc376bdfc179a018931a8f43dea4 (patch) | |
tree | 534004708e588143978eee01bac91227cad942cb /lib/test_overflow.c | |
parent | 0e836c3bea7da04cd4e2ed22d8c20654d5a09273 (diff) |
spi: Fix zero length xfer bug
This fixes a bug for messages containing both zero length and
unidirectional xfers.
The function spi_map_msg will allocate dummy tx and/or rx buffers
for use with unidirectional transfers when the hardware can only do
a bidirectional transfer. That dummy buffer will be used in place
of a NULL buffer even when the xfer length is 0.
Then in the function __spi_map_msg, if he hardware can dma,
the zero length xfer will have spi_map_buf called on the dummy
buffer.
Eventually, __sg_alloc_table is called and returns -EINVAL
because nents == 0.
This fix prevents the error by not using the dummy buffer when
the xfer length is zero.
Signed-off-by: Chris Lesiak <[email protected]>
Signed-off-by: Mark Brown <[email protected]>
Diffstat (limited to 'lib/test_overflow.c')
0 files changed, 0 insertions, 0 deletions