diff options
author | Janusz.Dziedzic@tieto.com | 2012-11-07 14:42:19 +0100 |
---|---|---|
committer | Luciano Coelho | 2012-11-16 18:53:01 +0100 |
commit | 4eeac22c159f053ea34527e4fea359ab10b4b5a5 (patch) | |
tree | 54aa3c8e7732412d0e97237b2aa9db3846e4ea82 /drivers | |
parent | drivers/net/wireless/ti/wl1251: remove CONFIG_EXPERIMENTAL (diff) | |
download | kernel-qcow2-linux-4eeac22c159f053ea34527e4fea359ab10b4b5a5.tar.gz kernel-qcow2-linux-4eeac22c159f053ea34527e4fea359ab10b4b5a5.tar.xz kernel-qcow2-linux-4eeac22c159f053ea34527e4fea359ab10b4b5a5.zip |
wlcore: SPI - fix spi transfer_list
In corner case for wl12xx_spi_raw_write() when
len == SPI_AGGR_BUFFER_SIZE
we don't setup correctly spi transfer_list.
Next we will have garbage and strange errors
reported by SPI framework (eg. wrong speed_hz,
failed to transfer one message from queue)
when iterate transfer_list.
Signed-off-by: Janusz Dziedzic <janusz.dziedzic@tieto.com>
Signed-off-by: Luciano Coelho <luca@coelho.fi>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/net/wireless/ti/wlcore/spi.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/net/wireless/ti/wlcore/spi.c b/drivers/net/wireless/ti/wlcore/spi.c index 76838a4a74ce..9d18f2ff57d0 100644 --- a/drivers/net/wireless/ti/wlcore/spi.c +++ b/drivers/net/wireless/ti/wlcore/spi.c @@ -270,7 +270,7 @@ static int __must_check wl12xx_spi_raw_write(struct device *child, int addr, void *buf, size_t len, bool fixed) { struct wl12xx_spi_glue *glue = dev_get_drvdata(child->parent); - struct spi_transfer t[2 * WSPI_MAX_NUM_OF_CHUNKS]; + struct spi_transfer t[2 * (WSPI_MAX_NUM_OF_CHUNKS + 1)]; struct spi_message m; u32 commands[WSPI_MAX_NUM_OF_CHUNKS]; u32 *cmd; |