diff options
author | Haavard Skinnemoen <hskinnemoen@atmel.com> | 2008-02-06 04:38:11 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2008-02-06 13:41:10 -0500 |
commit | 1eed29df472a33bba013d5a2ea2f9e32f4414397 (patch) | |
tree | 857d8c03baab8c845cd94cd601caab05e57dcb5b | |
parent | 3c72426f0539c1abce17918d1456f7a6a5a11f90 (diff) |
atmel_spi throughput improvement
Don't insert (undesirable) delays between consecutive words (DLYBCT) or when
activating chipselects (DLYBS).
Removing the between-word delays improves the performance of bulk transfers
(such as mtd_dataflash, m25p80, mmc_spi) significantly. In one test, the
improvement was a factor of more than eight!
(The large DLYBCT value came from the legacy at91 SPI driver, and it's not
clear why it used such a huge value.)
Signed-off-by: Haavard Skinnemoen <hskinnemoen@atmel.com>
Signed-off-by: David Brownell <dbrownell@users.sourceforge.net>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r-- | drivers/spi/atmel_spi.c | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/drivers/spi/atmel_spi.c b/drivers/spi/atmel_spi.c index ff10808183a3..b09d33678dd8 100644 --- a/drivers/spi/atmel_spi.c +++ b/drivers/spi/atmel_spi.c | |||
@@ -490,9 +490,14 @@ static int atmel_spi_setup(struct spi_device *spi) | |||
490 | if (!(spi->mode & SPI_CPHA)) | 490 | if (!(spi->mode & SPI_CPHA)) |
491 | csr |= SPI_BIT(NCPHA); | 491 | csr |= SPI_BIT(NCPHA); |
492 | 492 | ||
493 | /* TODO: DLYBS and DLYBCT */ | 493 | /* DLYBS is mostly irrelevant since we manage chipselect using GPIOs. |
494 | csr |= SPI_BF(DLYBS, 10); | 494 | * |
495 | csr |= SPI_BF(DLYBCT, 10); | 495 | * DLYBCT would add delays between words, slowing down transfers. |
496 | * It could potentially be useful to cope with DMA bottlenecks, but | ||
497 | * in those cases it's probably best to just use a lower bitrate. | ||
498 | */ | ||
499 | csr |= SPI_BF(DLYBS, 0); | ||
500 | csr |= SPI_BF(DLYBCT, 0); | ||
496 | 501 | ||
497 | /* chipselect must have been muxed as GPIO (e.g. in board setup) */ | 502 | /* chipselect must have been muxed as GPIO (e.g. in board setup) */ |
498 | npcs_pin = (unsigned int)spi->controller_data; | 503 | npcs_pin = (unsigned int)spi->controller_data; |