diff options
| author | Wolfgang Muees <[email protected]> | 2009-04-06 19:00:53 -0700 |
|---|---|---|
| committer | Linus Torvalds <[email protected]> | 2009-04-07 08:31:06 -0700 |
| commit | 93b61bddc13d9acf1fe341b39d826e80f3182d1e (patch) | |
| tree | 54a5b574ada4b619a9cba845bee1e4205d62176c /tools/perf/scripts/python | |
| parent | 42c78b2bf51bafb4cfa98dfecc28dd9b8bcd04b0 (diff) | |
Blackfin SPI Driver: Make mmc_spi driver work on Blackfin
1. Rewrite of the non-dma data transfer functions to use only ONE mode
of TIMOD (TIMOD=0x1). With TIMOD=0, it was not possible to set the TX
bit pattern. So the TDBR = 0xFFFF inside the read calls won't work.
2. Clear SPI_RDBR before reading and before duplex transfer.
Otherwise the garbage data in RDBR will get read. Since mmc_spi uses a
lot of duplex transfers, this is the main cause of mmc_spi failure.
3. Poll RXS for transfer completion. Polling SPIF or TXS cannot
guarantee transfer completion. This may interrupt a transfer before it
is finished. Also this may leave garbage data in buffer and affect
next transfer.
[Yi Li <[email protected]>: add a field "u16 idle_tx_val" in "struct
bfin5xx_spi_chip" to specify the value to transmit if no TX value
is supplied.]
Signed-off-by: Wolfgang Muees <[email protected]>
Signed-off-by: Yi Li <[email protected]>
Signed-off-by: Bryan Wu <[email protected]>
Cc: David Brownell <[email protected]>
Signed-off-by: Andrew Morton <[email protected]>
Signed-off-by: Linus Torvalds <[email protected]>
Diffstat (limited to 'tools/perf/scripts/python')
0 files changed, 0 insertions, 0 deletions