aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/spi
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/spi')
-rw-r--r--drivers/spi/spi_mpc83xx.c21
1 files changed, 13 insertions, 8 deletions
diff --git a/drivers/spi/spi_mpc83xx.c b/drivers/spi/spi_mpc83xx.c
index 0c16a2b39b41..fe69e94043e1 100644
--- a/drivers/spi/spi_mpc83xx.c
+++ b/drivers/spi/spi_mpc83xx.c
@@ -86,7 +86,7 @@ struct mpc83xx_spi {
86 86
87 unsigned nsecs; /* (clock cycle time)/2 */ 87 unsigned nsecs; /* (clock cycle time)/2 */
88 88
89 u32 sysclk; 89 u32 spibrg; /* SPIBRG input clock */
90 u32 rx_shift; /* RX data reg shift when in qe mode */ 90 u32 rx_shift; /* RX data reg shift when in qe mode */
91 u32 tx_shift; /* TX data reg shift when in qe mode */ 91 u32 tx_shift; /* TX data reg shift when in qe mode */
92 92
@@ -169,17 +169,18 @@ static void mpc83xx_spi_chipselect(struct spi_device *spi, int value)
169 169
170 regval |= SPMODE_LEN(len); 170 regval |= SPMODE_LEN(len);
171 171
172 if ((mpc83xx_spi->sysclk / spi->max_speed_hz) >= 64) { 172 if ((mpc83xx_spi->spibrg / spi->max_speed_hz) >= 64) {
173 u8 pm = mpc83xx_spi->sysclk / (spi->max_speed_hz * 64); 173 u8 pm = mpc83xx_spi->spibrg / (spi->max_speed_hz * 64);
174 if (pm > 0x0f) { 174 if (pm > 0x0f) {
175 printk(KERN_WARNING "MPC83xx SPI: SPICLK can't be less then a SYSCLK/1024!\n" 175 dev_err(&spi->dev, "Requested speed is too "
176 "Requested SPICLK is %d Hz. Will use %d Hz instead.\n", 176 "low: %d Hz. Will use %d Hz instead.\n",
177 spi->max_speed_hz, mpc83xx_spi->sysclk / 1024); 177 spi->max_speed_hz,
178 mpc83xx_spi->spibrg / 1024);
178 pm = 0x0f; 179 pm = 0x0f;
179 } 180 }
180 regval |= SPMODE_PM(pm) | SPMODE_DIV16; 181 regval |= SPMODE_PM(pm) | SPMODE_DIV16;
181 } else { 182 } else {
182 u8 pm = mpc83xx_spi->sysclk / (spi->max_speed_hz * 4); 183 u8 pm = mpc83xx_spi->spibrg / (spi->max_speed_hz * 4);
183 regval |= SPMODE_PM(pm); 184 regval |= SPMODE_PM(pm);
184 } 185 }
185 186
@@ -429,13 +430,17 @@ static int __init mpc83xx_spi_probe(struct platform_device *dev)
429 mpc83xx_spi->bitbang.chipselect = mpc83xx_spi_chipselect; 430 mpc83xx_spi->bitbang.chipselect = mpc83xx_spi_chipselect;
430 mpc83xx_spi->bitbang.setup_transfer = mpc83xx_spi_setup_transfer; 431 mpc83xx_spi->bitbang.setup_transfer = mpc83xx_spi_setup_transfer;
431 mpc83xx_spi->bitbang.txrx_bufs = mpc83xx_spi_bufs; 432 mpc83xx_spi->bitbang.txrx_bufs = mpc83xx_spi_bufs;
432 mpc83xx_spi->sysclk = pdata->sysclk;
433 mpc83xx_spi->activate_cs = pdata->activate_cs; 433 mpc83xx_spi->activate_cs = pdata->activate_cs;
434 mpc83xx_spi->deactivate_cs = pdata->deactivate_cs; 434 mpc83xx_spi->deactivate_cs = pdata->deactivate_cs;
435 mpc83xx_spi->qe_mode = pdata->qe_mode; 435 mpc83xx_spi->qe_mode = pdata->qe_mode;
436 mpc83xx_spi->get_rx = mpc83xx_spi_rx_buf_u8; 436 mpc83xx_spi->get_rx = mpc83xx_spi_rx_buf_u8;
437 mpc83xx_spi->get_tx = mpc83xx_spi_tx_buf_u8; 437 mpc83xx_spi->get_tx = mpc83xx_spi_tx_buf_u8;
438 438
439 if (mpc83xx_spi->qe_mode)
440 mpc83xx_spi->spibrg = pdata->sysclk / 2;
441 else
442 mpc83xx_spi->spibrg = pdata->sysclk;
443
439 mpc83xx_spi->rx_shift = 0; 444 mpc83xx_spi->rx_shift = 0;
440 mpc83xx_spi->tx_shift = 0; 445 mpc83xx_spi->tx_shift = 0;
441 if (mpc83xx_spi->qe_mode) { 446 if (mpc83xx_spi->qe_mode) {