diff options
-rw-r--r-- | arch/arm/mach-davinci/dm355.c | 1 | ||||
-rw-r--r-- | arch/arm/mach-davinci/dm365.c | 1 | ||||
-rw-r--r-- | arch/arm/mach-davinci/include/mach/spi.h | 1 | ||||
-rw-r--r-- | drivers/spi/davinci_spi.c | 53 |
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); |