aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/spi
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/spi')
-rw-r--r--drivers/spi/spi_mpc83xx.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/drivers/spi/spi_mpc83xx.c b/drivers/spi/spi_mpc83xx.c
index 0b99fd9f5171..e2d8dbc15c80 100644
--- a/drivers/spi/spi_mpc83xx.c
+++ b/drivers/spi/spi_mpc83xx.c
@@ -153,7 +153,8 @@ static void mpc83xx_spi_chipselect(struct spi_device *spi, int value)
153 len = len - 1; 153 len = len - 1;
154 154
155 /* mask out bits we are going to set */ 155 /* mask out bits we are going to set */
156 regval &= ~0x38ff0000; 156 regval &= ~(SPMODE_CP_BEGIN_EDGECLK | SPMODE_CI_INACTIVEHIGH |
157 SPMODE_LEN(0xF) | SPMODE_DIV16 | SPMODE_PM(0xF));
157 158
158 if (spi->mode & SPI_CPHA) 159 if (spi->mode & SPI_CPHA)
159 regval |= SPMODE_CP_BEGIN_EDGECLK; 160 regval |= SPMODE_CP_BEGIN_EDGECLK;
@@ -248,7 +249,7 @@ int mpc83xx_spi_setup_transfer(struct spi_device *spi, struct spi_transfer *t)
248 regval = mpc83xx_spi_read_reg(&mpc83xx_spi->base->mode); 249 regval = mpc83xx_spi_read_reg(&mpc83xx_spi->base->mode);
249 250
250 /* Mask out bits_per_wordgth */ 251 /* Mask out bits_per_wordgth */
251 regval &= 0xff0fffff; 252 regval &= ~SPMODE_LEN(0xF);
252 regval |= SPMODE_LEN(bits_per_word); 253 regval |= SPMODE_LEN(bits_per_word);
253 254
254 /* Turn off SPI unit prior changing mode */ 255 /* Turn off SPI unit prior changing mode */