Commit 5f3e43db authored by Peter Ujfalusi's avatar Peter Ujfalusi Committed by Tony Lindgren

[PATCH] ARM: OMAP: omap2_mcspi: fix for channel configuration and CS

Fix for channel reconfiguration case: once the EPOL, POL or PHA has been
configured to 1, further configuration on the channel can't change it to 0.

The first CS enable is not needed. The CS will be enabled right before
the transfer anyway, if it's not active.
Signed-off-by: default avatarPeter Ujfalusi <peter.ujfalusi@nokia.com>
Signed-off-by: default avatarTony Lindgren <tony@atomide.com>
parent 683fd3ba
...@@ -307,12 +307,18 @@ static int omap2_mcspi_setup_transfer(struct spi_device *spi, ...@@ -307,12 +307,18 @@ static int omap2_mcspi_setup_transfer(struct spi_device *spi,
l |= (word_len - 1) << 7; l |= (word_len - 1) << 7;
if (!(spi->mode & SPI_CS_HIGH)) if (!(spi->mode & SPI_CS_HIGH))
l |= OMAP2_MCSPI_CHCONF_EPOL; l |= OMAP2_MCSPI_CHCONF_EPOL;
else
l &= ~OMAP2_MCSPI_CHCONF_EPOL;
l &= ~OMAP2_MCSPI_CHCONF_CLKD_MASK; l &= ~OMAP2_MCSPI_CHCONF_CLKD_MASK;
l |= div << 2; l |= div << 2;
if (spi->mode & SPI_CPOL) if (spi->mode & SPI_CPOL)
l |= OMAP2_MCSPI_CHCONF_POL; l |= OMAP2_MCSPI_CHCONF_POL;
else
l &= ~OMAP2_MCSPI_CHCONF_POL;
if (spi->mode & SPI_CPHA) if (spi->mode & SPI_CPHA)
l |= OMAP2_MCSPI_CHCONF_PHA; l |= OMAP2_MCSPI_CHCONF_PHA;
else
l &= ~OMAP2_MCSPI_CHCONF_PHA;
mcspi_write_cs_reg(spi, OMAP2_MCSPI_CHCONF0, l); mcspi_write_cs_reg(spi, OMAP2_MCSPI_CHCONF0, l);
return 0; return 0;
...@@ -349,7 +355,7 @@ static void omap2_mcspi_work(unsigned long arg) ...@@ -349,7 +355,7 @@ static void omap2_mcspi_work(unsigned long arg)
struct spi_message *m; struct spi_message *m;
struct spi_device *spi; struct spi_device *spi;
struct spi_transfer *t = NULL; struct spi_transfer *t = NULL;
int cs_active; int cs_active = 0;
struct omap2_mcspi_device_config *conf; struct omap2_mcspi_device_config *conf;
struct omap2_mcspi_cs *cs; struct omap2_mcspi_cs *cs;
int par_override = 0; int par_override = 0;
...@@ -365,9 +371,6 @@ static void omap2_mcspi_work(unsigned long arg) ...@@ -365,9 +371,6 @@ static void omap2_mcspi_work(unsigned long arg)
conf = (struct omap2_mcspi_device_config *) spi->controller_data; conf = (struct omap2_mcspi_device_config *) spi->controller_data;
cs = (struct omap2_mcspi_cs *) spi->controller_state; cs = (struct omap2_mcspi_cs *) spi->controller_state;
omap2_mcspi_force_cs(spi, 1);
cs_active = 1;
list_for_each_entry(t, &m->transfers, transfer_list) { list_for_each_entry(t, &m->transfers, transfer_list) {
if (t->tx_buf == NULL && t->rx_buf == NULL && t->len) { if (t->tx_buf == NULL && t->rx_buf == NULL && t->len) {
status = -EINVAL; status = -EINVAL;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment