aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorHaavard Skinnemoen <hskinnemoen@atmel.com>2008-02-06 04:38:11 -0500
committerLinus Torvalds <torvalds@woody.linux-foundation.org>2008-02-06 13:41:10 -0500
commit1eed29df472a33bba013d5a2ea2f9e32f4414397 (patch)
tree857d8c03baab8c845cd94cd601caab05e57dcb5b /drivers
parent3c72426f0539c1abce17918d1456f7a6a5a11f90 (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>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/spi/atmel_spi.c11
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;