mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-26 06:30:39 +00:00
SPI: Fix 32 bit transfers in mxc_spi.c
Commit f9b6a1575d
, "i.MX31: fix SPI
driver for shorter than 32 bit" broke 32 bit transfers. This patch
makes single 32 bit transfer work again.
Transfer lengths that are known not to work will abort and print
an error message.
Tested on i.MX31 Litekit and i.MX31 PDK using 32 bit transfers to
the MC13783/ATLAS chip (using the 'date' command).
Signed-off-by: Magnus Lilja <lilja.magnus@gmail.com>
This commit is contained in:
parent
39a9142203
commit
eff536befd
1 changed files with 9 additions and 0 deletions
|
@ -131,6 +131,13 @@ int spi_xfer(struct spi_slave *slave, unsigned int bitlen, const void *dout,
|
|||
return 1;
|
||||
}
|
||||
|
||||
/* This driver is currently partly broken, alert the user */
|
||||
if (bitlen > 16 && (bitlen % 32)) {
|
||||
printf("Error: SPI transfer with bitlen=%d is broken.\n",
|
||||
bitlen);
|
||||
return 1;
|
||||
}
|
||||
|
||||
for (i = 0, in_l = (u32 *)din, out_l = (u32 *)dout;
|
||||
i < n_blks;
|
||||
i++, in_l++, out_l++, bitlen -= 32) {
|
||||
|
@ -142,6 +149,8 @@ int spi_xfer(struct spi_slave *slave, unsigned int bitlen, const void *dout,
|
|||
*(u8 *)din = data;
|
||||
else if (bitlen < 17)
|
||||
*(u16 *)din = data;
|
||||
else
|
||||
*in_l = data;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue