aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--arch/arm/mach-davinci/dm355.c1
-rw-r--r--arch/arm/mach-davinci/dm365.c1
-rw-r--r--arch/arm/mach-davinci/include/mach/spi.h1
-rw-r--r--drivers/spi/davinci_spi.c53
4 files changed, 18 insertions, 38 deletions
diff --git a/arch/arm/mach-davinci/dm355.c b/arch/arm/mach-davinci/dm355.c
index 9be261beae7d..6a76dfa60ef7 100644
--- a/arch/arm/mach-davinci/dm355.c
+++ b/arch/arm/mach-davinci/dm355.c
@@ -413,7 +413,6 @@ static struct davinci_spi_platform_data dm355_spi0_pdata = {
413 .version = SPI_VERSION_1, 413 .version = SPI_VERSION_1,
414 .num_chipselect = 2, 414 .num_chipselect = 2,
415 .clk_internal = 1, 415 .clk_internal = 1,
416 .cs_hold = 1,
417 .intr_level = 0, 416 .intr_level = 0,
418 .poll_mode = 1, /* 0 -> interrupt mode 1-> polling mode */ 417 .poll_mode = 1, /* 0 -> interrupt mode 1-> polling mode */
419 .c2tdelay = 0, 418 .c2tdelay = 0,
diff --git a/arch/arm/mach-davinci/dm365.c b/arch/arm/mach-davinci/dm365.c
index a12065e87266..cd623db8d7d7 100644
--- a/arch/arm/mach-davinci/dm365.c
+++ b/arch/arm/mach-davinci/dm365.c
@@ -626,7 +626,6 @@ static struct davinci_spi_platform_data dm365_spi0_pdata = {
626 .version = SPI_VERSION_1, 626 .version = SPI_VERSION_1,
627 .num_chipselect = 2, 627 .num_chipselect = 2,
628 .clk_internal = 1, 628 .clk_internal = 1,
629 .cs_hold = 1,
630 .intr_level = 0, 629 .intr_level = 0,
631 .poll_mode = 1, /* 0 -> interrupt mode 1-> polling mode */ 630 .poll_mode = 1, /* 0 -> interrupt mode 1-> polling mode */
632 .c2tdelay = 0, 631 .c2tdelay = 0,
diff --git a/arch/arm/mach-davinci/include/mach/spi.h b/arch/arm/mach-davinci/include/mach/spi.h
index 910efbf099c0..2cb326e536bb 100644
--- a/arch/arm/mach-davinci/include/mach/spi.h
+++ b/arch/arm/mach-davinci/include/mach/spi.h
@@ -33,7 +33,6 @@ struct davinci_spi_platform_data {
33 u8 wait_enable; 33 u8 wait_enable;
34 u8 timer_disable; 34 u8 timer_disable;
35 u8 clk_internal; 35 u8 clk_internal;
36 u8 cs_hold;
37 u8 intr_level; 36 u8 intr_level;
38 u8 poll_mode; 37 u8 poll_mode;
39 u8 use_dma; 38 u8 use_dma;
diff --git a/drivers/spi/davinci_spi.c b/drivers/spi/davinci_spi.c
index d6b6a4958088..105c686b2cea 100644
--- a/drivers/spi/davinci_spi.c
+++ b/drivers/spi/davinci_spi.c
@@ -66,7 +66,7 @@
66#define SPI_INTLVL_0 0x00000000u 66#define SPI_INTLVL_0 0x00000000u
67 67
68/* SPIDAT1 */ 68/* SPIDAT1 */
69#define SPIDAT1_CSHOLD_SHIFT 28 69#define SPIDAT1_CSHOLD_MASK BIT(28)
70#define SPIDAT1_CSNR_SHIFT 16 70#define SPIDAT1_CSNR_SHIFT 16
71#define SPIGCR1_CLKMOD_MASK BIT(1) 71#define SPIGCR1_CLKMOD_MASK BIT(1)
72#define SPIGCR1_MASTER_MASK BIT(0) 72#define SPIGCR1_MASTER_MASK BIT(0)
@@ -235,7 +235,8 @@ static void davinci_spi_chipselect(struct spi_device *spi, int value)
235{ 235{
236 struct davinci_spi *davinci_spi; 236 struct davinci_spi *davinci_spi;
237 struct davinci_spi_platform_data *pdata; 237 struct davinci_spi_platform_data *pdata;
238 u32 data1_reg_val = 0; 238 u32 data1_reg_val;
239 u8 chip_sel = spi->chip_select;
239 240
240 davinci_spi = spi_master_get_devdata(spi->master); 241 davinci_spi = spi_master_get_devdata(spi->master);
241 pdata = davinci_spi->pdata; 242 pdata = davinci_spi->pdata;
@@ -244,14 +245,17 @@ static void davinci_spi_chipselect(struct spi_device *spi, int value)
244 * Board specific chip select logic decides the polarity and cs 245 * Board specific chip select logic decides the polarity and cs
245 * line for the controller 246 * line for the controller
246 */ 247 */
247 if (value == BITBANG_CS_INACTIVE) { 248 data1_reg_val = CS_DEFAULT << SPIDAT1_CSNR_SHIFT;
248 data1_reg_val |= CS_DEFAULT << SPIDAT1_CSNR_SHIFT; 249 if (value == BITBANG_CS_ACTIVE) {
249 iowrite32(data1_reg_val, davinci_spi->base + SPIDAT1); 250 data1_reg_val |= SPIDAT1_CSHOLD_MASK;
250 251 data1_reg_val &= ~((0x1 << chip_sel) << SPIDAT1_CSNR_SHIFT);
251 while ((ioread32(davinci_spi->base + SPIBUF)
252 & SPIBUF_RXEMPTY_MASK) == 0)
253 cpu_relax();
254 } 252 }
253
254 iowrite32(data1_reg_val, davinci_spi->base + SPIDAT1);
255 while ((ioread32(davinci_spi->base + SPIBUF)
256 & SPIBUF_RXEMPTY_MASK) == 0)
257 cpu_relax();
258
255} 259}
256 260
257/** 261/**
@@ -632,7 +636,7 @@ static int davinci_spi_bufs_pio(struct spi_device *spi, struct spi_transfer *t)
632{ 636{
633 struct davinci_spi *davinci_spi; 637 struct davinci_spi *davinci_spi;
634 int int_status, count, ret; 638 int int_status, count, ret;
635 u8 conv, tmp; 639 u8 conv;
636 u32 tx_data, data1_reg_val; 640 u32 tx_data, data1_reg_val;
637 u32 buf_val, flg_val; 641 u32 buf_val, flg_val;
638 struct davinci_spi_platform_data *pdata; 642 struct davinci_spi_platform_data *pdata;
@@ -647,6 +651,8 @@ static int davinci_spi_bufs_pio(struct spi_device *spi, struct spi_transfer *t)
647 conv = davinci_spi->slave[spi->chip_select].bytes_per_word; 651 conv = davinci_spi->slave[spi->chip_select].bytes_per_word;
648 davinci_spi->count = t->len / conv; 652 davinci_spi->count = t->len / conv;
649 653
654 data1_reg_val = ioread32(davinci_spi->base + SPIDAT1);
655
650 INIT_COMPLETION(davinci_spi->done); 656 INIT_COMPLETION(davinci_spi->done);
651 657
652 ret = davinci_spi_bufs_prep(spi, davinci_spi); 658 ret = davinci_spi_bufs_prep(spi, davinci_spi);
@@ -661,16 +667,6 @@ static int davinci_spi_bufs_pio(struct spi_device *spi, struct spi_transfer *t)
661 davinci_spi->base + SPIDELAY); 667 davinci_spi->base + SPIDELAY);
662 668
663 count = davinci_spi->count; 669 count = davinci_spi->count;
664 data1_reg_val = pdata->cs_hold << SPIDAT1_CSHOLD_SHIFT;
665 tmp = ~(0x1 << spi->chip_select);
666
667 clear_io_bits(davinci_spi->base + SPIDEF, ~tmp);
668
669 data1_reg_val |= tmp << SPIDAT1_CSNR_SHIFT;
670
671 while ((ioread32(davinci_spi->base + SPIBUF)
672 & SPIBUF_RXEMPTY_MASK) == 0)
673 cpu_relax();
674 670
675 /* Determine the command to execute READ or WRITE */ 671 /* Determine the command to execute READ or WRITE */
676 if (t->tx_buf) { 672 if (t->tx_buf) {
@@ -770,7 +766,6 @@ static int davinci_spi_bufs_dma(struct spi_device *spi, struct spi_transfer *t)
770 int int_status = 0; 766 int int_status = 0;
771 int count, temp_count; 767 int count, temp_count;
772 u8 conv = 1; 768 u8 conv = 1;
773 u8 tmp;
774 u32 data1_reg_val; 769 u32 data1_reg_val;
775 struct davinci_spi_dma *davinci_spi_dma; 770 struct davinci_spi_dma *davinci_spi_dma;
776 int word_len, data_type, ret; 771 int word_len, data_type, ret;
@@ -794,6 +789,8 @@ static int davinci_spi_bufs_dma(struct spi_device *spi, struct spi_transfer *t)
794 conv = davinci_spi->slave[spi->chip_select].bytes_per_word; 789 conv = davinci_spi->slave[spi->chip_select].bytes_per_word;
795 davinci_spi->count = t->len / conv; 790 davinci_spi->count = t->len / conv;
796 791
792 data1_reg_val = ioread32(davinci_spi->base + SPIDAT1);
793
797 INIT_COMPLETION(davinci_spi->done); 794 INIT_COMPLETION(davinci_spi->done);
798 795
799 init_completion(&davinci_spi_dma->dma_rx_completion); 796 init_completion(&davinci_spi_dma->dma_rx_completion);
@@ -820,28 +817,14 @@ static int davinci_spi_bufs_dma(struct spi_device *spi, struct spi_transfer *t)
820 davinci_spi->base + SPIDELAY); 817 davinci_spi->base + SPIDELAY);
821 818
822 count = davinci_spi->count; /* the number of elements */ 819 count = davinci_spi->count; /* the number of elements */
823 data1_reg_val = pdata->cs_hold << SPIDAT1_CSHOLD_SHIFT;
824
825 /* CS default = 0xFF */
826 tmp = ~(0x1 << spi->chip_select);
827
828 clear_io_bits(davinci_spi->base + SPIDEF, ~tmp);
829
830 data1_reg_val |= tmp << SPIDAT1_CSNR_SHIFT;
831 820
832 /* disable all interrupts for dma transfers */ 821 /* disable all interrupts for dma transfers */
833 clear_io_bits(davinci_spi->base + SPIINT, SPIINT_MASKALL); 822 clear_io_bits(davinci_spi->base + SPIINT, SPIINT_MASKALL);
834 /* Disable SPI to write configuration bits in SPIDAT */ 823 /* Disable SPI to write configuration bits in SPIDAT */
835 clear_io_bits(davinci_spi->base + SPIGCR1, SPIGCR1_SPIENA_MASK); 824 clear_io_bits(davinci_spi->base + SPIGCR1, SPIGCR1_SPIENA_MASK);
836 iowrite32(data1_reg_val, davinci_spi->base + SPIDAT1);
837 /* Enable SPI */ 825 /* Enable SPI */
838 set_io_bits(davinci_spi->base + SPIGCR1, SPIGCR1_SPIENA_MASK); 826 set_io_bits(davinci_spi->base + SPIGCR1, SPIGCR1_SPIENA_MASK);
839 827
840 while ((ioread32(davinci_spi->base + SPIBUF)
841 & SPIBUF_RXEMPTY_MASK) == 0)
842 cpu_relax();
843
844
845 if (t->tx_buf) { 828 if (t->tx_buf) {
846 t->tx_dma = dma_map_single(&spi->dev, (void *)t->tx_buf, count, 829 t->tx_dma = dma_map_single(&spi->dev, (void *)t->tx_buf, count,
847 DMA_TO_DEVICE); 830 DMA_TO_DEVICE);