summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid Rivshin <DRivshin@allworx.com>2019-02-19 02:04:29 +0300
committerTom Rini <trini@konsulko.com>2019-02-28 22:21:46 +0300
commitb8b88e6aff3ea7346a39bfbb27124b275ce56666 (patch)
tree411f2aabc69a107c4867d981c3d107f0e4c2da29
parent783e66816d101f970b185083377846059d4d577d (diff)
downloadu-boot-b8b88e6aff3ea7346a39bfbb27124b275ce56666.tar.xz
spi: omap3: fix set_wordlen() reading from incorrect address for CHCONF
_omap3_spi_set_wordlen() indexed the regs->channel[] array with the old wordlen (instead of the chipselect number) when reading the current CHCONF register value. This meant it read from the wrong memory location, modified that value, and then wrote it back to the correct CHCONF register. The end result is that most slave configuration settings would be lost, such as clock divisor, clock/chipselect polarities, etc. Fixes: 77b8d04854f4 ("spi: omap3: Convert to driver model") Signed-off-by: David Rivshin <drivshin@allworx.com>
-rw-r--r--drivers/spi/omap3_spi.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/spi/omap3_spi.c b/drivers/spi/omap3_spi.c
index c7fcf050a5..ff4c700645 100644
--- a/drivers/spi/omap3_spi.c
+++ b/drivers/spi/omap3_spi.c
@@ -415,7 +415,7 @@ static void _omap3_spi_set_wordlen(struct omap3_spi_priv *priv)
unsigned int confr;
/* McSPI individual channel configuration */
- confr = readl(&priv->regs->channel[priv->wordlen].chconf);
+ confr = readl(&priv->regs->channel[priv->cs].chconf);
/* wordlength */
confr &= ~OMAP3_MCSPI_CHCONF_WL_MASK;