diff options
-rw-r--r-- | drivers/spi/davinci_spi.c | 409 |
1 files changed, 198 insertions, 211 deletions
diff --git a/drivers/spi/davinci_spi.c b/drivers/spi/davinci_spi.c index f6f63d058140..6beab99bf95b 100644 --- a/drivers/spi/davinci_spi.c +++ b/drivers/spi/davinci_spi.c | |||
@@ -115,8 +115,8 @@ | |||
115 | 115 | ||
116 | /* We have 2 DMA channels per CS, one for RX and one for TX */ | 116 | /* We have 2 DMA channels per CS, one for RX and one for TX */ |
117 | struct davinci_spi_dma { | 117 | struct davinci_spi_dma { |
118 | int dma_tx_channel; | 118 | int tx_channel; |
119 | int dma_rx_channel; | 119 | int rx_channel; |
120 | int dummy_param_slot; | 120 | int dummy_param_slot; |
121 | enum dma_event_q eventq; | 121 | enum dma_event_q eventq; |
122 | }; | 122 | }; |
@@ -138,7 +138,7 @@ struct davinci_spi { | |||
138 | u8 rx_tmp_buf[SPI_TMP_BUFSZ]; | 138 | u8 rx_tmp_buf[SPI_TMP_BUFSZ]; |
139 | int rcount; | 139 | int rcount; |
140 | int wcount; | 140 | int wcount; |
141 | struct davinci_spi_dma dma_channels; | 141 | struct davinci_spi_dma dma; |
142 | struct davinci_spi_platform_data *pdata; | 142 | struct davinci_spi_platform_data *pdata; |
143 | 143 | ||
144 | void (*get_rx)(u32 rx_data, struct davinci_spi *); | 144 | void (*get_rx)(u32 rx_data, struct davinci_spi *); |
@@ -149,42 +149,42 @@ struct davinci_spi { | |||
149 | 149 | ||
150 | static struct davinci_spi_config davinci_spi_default_cfg; | 150 | static struct davinci_spi_config davinci_spi_default_cfg; |
151 | 151 | ||
152 | static void davinci_spi_rx_buf_u8(u32 data, struct davinci_spi *davinci_spi) | 152 | static void davinci_spi_rx_buf_u8(u32 data, struct davinci_spi *dspi) |
153 | { | 153 | { |
154 | if (davinci_spi->rx) { | 154 | if (dspi->rx) { |
155 | u8 *rx = davinci_spi->rx; | 155 | u8 *rx = dspi->rx; |
156 | *rx++ = (u8)data; | 156 | *rx++ = (u8)data; |
157 | davinci_spi->rx = rx; | 157 | dspi->rx = rx; |
158 | } | 158 | } |
159 | } | 159 | } |
160 | 160 | ||
161 | static void davinci_spi_rx_buf_u16(u32 data, struct davinci_spi *davinci_spi) | 161 | static void davinci_spi_rx_buf_u16(u32 data, struct davinci_spi *dspi) |
162 | { | 162 | { |
163 | if (davinci_spi->rx) { | 163 | if (dspi->rx) { |
164 | u16 *rx = davinci_spi->rx; | 164 | u16 *rx = dspi->rx; |
165 | *rx++ = (u16)data; | 165 | *rx++ = (u16)data; |
166 | davinci_spi->rx = rx; | 166 | dspi->rx = rx; |
167 | } | 167 | } |
168 | } | 168 | } |
169 | 169 | ||
170 | static u32 davinci_spi_tx_buf_u8(struct davinci_spi *davinci_spi) | 170 | static u32 davinci_spi_tx_buf_u8(struct davinci_spi *dspi) |
171 | { | 171 | { |
172 | u32 data = 0; | 172 | u32 data = 0; |
173 | if (davinci_spi->tx) { | 173 | if (dspi->tx) { |
174 | const u8 *tx = davinci_spi->tx; | 174 | const u8 *tx = dspi->tx; |
175 | data = *tx++; | 175 | data = *tx++; |
176 | davinci_spi->tx = tx; | 176 | dspi->tx = tx; |
177 | } | 177 | } |
178 | return data; | 178 | return data; |
179 | } | 179 | } |
180 | 180 | ||
181 | static u32 davinci_spi_tx_buf_u16(struct davinci_spi *davinci_spi) | 181 | static u32 davinci_spi_tx_buf_u16(struct davinci_spi *dspi) |
182 | { | 182 | { |
183 | u32 data = 0; | 183 | u32 data = 0; |
184 | if (davinci_spi->tx) { | 184 | if (dspi->tx) { |
185 | const u16 *tx = davinci_spi->tx; | 185 | const u16 *tx = dspi->tx; |
186 | data = *tx++; | 186 | data = *tx++; |
187 | davinci_spi->tx = tx; | 187 | dspi->tx = tx; |
188 | } | 188 | } |
189 | return data; | 189 | return data; |
190 | } | 190 | } |
@@ -210,14 +210,14 @@ static inline void clear_io_bits(void __iomem *addr, u32 bits) | |||
210 | */ | 210 | */ |
211 | static void davinci_spi_chipselect(struct spi_device *spi, int value) | 211 | static void davinci_spi_chipselect(struct spi_device *spi, int value) |
212 | { | 212 | { |
213 | struct davinci_spi *davinci_spi; | 213 | struct davinci_spi *dspi; |
214 | struct davinci_spi_platform_data *pdata; | 214 | struct davinci_spi_platform_data *pdata; |
215 | u8 chip_sel = spi->chip_select; | 215 | u8 chip_sel = spi->chip_select; |
216 | u16 spidat1_cfg = CS_DEFAULT; | 216 | u16 spidat1 = CS_DEFAULT; |
217 | bool gpio_chipsel = false; | 217 | bool gpio_chipsel = false; |
218 | 218 | ||
219 | davinci_spi = spi_master_get_devdata(spi->master); | 219 | dspi = spi_master_get_devdata(spi->master); |
220 | pdata = davinci_spi->pdata; | 220 | pdata = dspi->pdata; |
221 | 221 | ||
222 | if (pdata->chip_sel && chip_sel < pdata->num_chipselect && | 222 | if (pdata->chip_sel && chip_sel < pdata->num_chipselect && |
223 | pdata->chip_sel[chip_sel] != SPI_INTERN_CS) | 223 | pdata->chip_sel[chip_sel] != SPI_INTERN_CS) |
@@ -234,11 +234,11 @@ static void davinci_spi_chipselect(struct spi_device *spi, int value) | |||
234 | gpio_set_value(pdata->chip_sel[chip_sel], 1); | 234 | gpio_set_value(pdata->chip_sel[chip_sel], 1); |
235 | } else { | 235 | } else { |
236 | if (value == BITBANG_CS_ACTIVE) { | 236 | if (value == BITBANG_CS_ACTIVE) { |
237 | spidat1_cfg |= SPIDAT1_CSHOLD_MASK; | 237 | spidat1 |= SPIDAT1_CSHOLD_MASK; |
238 | spidat1_cfg &= ~(0x1 << chip_sel); | 238 | spidat1 &= ~(0x1 << chip_sel); |
239 | } | 239 | } |
240 | 240 | ||
241 | iowrite16(spidat1_cfg, davinci_spi->base + SPIDAT1 + 2); | 241 | iowrite16(spidat1, dspi->base + SPIDAT1 + 2); |
242 | } | 242 | } |
243 | } | 243 | } |
244 | 244 | ||
@@ -252,12 +252,12 @@ static void davinci_spi_chipselect(struct spi_device *spi, int value) | |||
252 | * Returns: calculated prescale - 1 for easy programming into SPI registers | 252 | * Returns: calculated prescale - 1 for easy programming into SPI registers |
253 | * or negative error number if valid prescalar cannot be updated. | 253 | * or negative error number if valid prescalar cannot be updated. |
254 | */ | 254 | */ |
255 | static inline int davinci_spi_get_prescale(struct davinci_spi *davinci_spi, | 255 | static inline int davinci_spi_get_prescale(struct davinci_spi *dspi, |
256 | u32 max_speed_hz) | 256 | u32 max_speed_hz) |
257 | { | 257 | { |
258 | int ret; | 258 | int ret; |
259 | 259 | ||
260 | ret = DIV_ROUND_UP(clk_get_rate(davinci_spi->clk), max_speed_hz); | 260 | ret = DIV_ROUND_UP(clk_get_rate(dspi->clk), max_speed_hz); |
261 | 261 | ||
262 | if (ret < 3 || ret > 256) | 262 | if (ret < 3 || ret > 256) |
263 | return -EINVAL; | 263 | return -EINVAL; |
@@ -278,12 +278,12 @@ static int davinci_spi_setup_transfer(struct spi_device *spi, | |||
278 | struct spi_transfer *t) | 278 | struct spi_transfer *t) |
279 | { | 279 | { |
280 | 280 | ||
281 | struct davinci_spi *davinci_spi; | 281 | struct davinci_spi *dspi; |
282 | struct davinci_spi_config *spicfg; | 282 | struct davinci_spi_config *spicfg; |
283 | u8 bits_per_word = 0; | 283 | u8 bits_per_word = 0; |
284 | u32 hz = 0, spifmt = 0, prescale = 0; | 284 | u32 hz = 0, spifmt = 0, prescale = 0; |
285 | 285 | ||
286 | davinci_spi = spi_master_get_devdata(spi->master); | 286 | dspi = spi_master_get_devdata(spi->master); |
287 | spicfg = (struct davinci_spi_config *)spi->controller_data; | 287 | spicfg = (struct davinci_spi_config *)spi->controller_data; |
288 | if (!spicfg) | 288 | if (!spicfg) |
289 | spicfg = &davinci_spi_default_cfg; | 289 | spicfg = &davinci_spi_default_cfg; |
@@ -302,13 +302,13 @@ static int davinci_spi_setup_transfer(struct spi_device *spi, | |||
302 | * 8bit, 16bit or 32bit transfer | 302 | * 8bit, 16bit or 32bit transfer |
303 | */ | 303 | */ |
304 | if (bits_per_word <= 8 && bits_per_word >= 2) { | 304 | if (bits_per_word <= 8 && bits_per_word >= 2) { |
305 | davinci_spi->get_rx = davinci_spi_rx_buf_u8; | 305 | dspi->get_rx = davinci_spi_rx_buf_u8; |
306 | davinci_spi->get_tx = davinci_spi_tx_buf_u8; | 306 | dspi->get_tx = davinci_spi_tx_buf_u8; |
307 | davinci_spi->bytes_per_word[spi->chip_select] = 1; | 307 | dspi->bytes_per_word[spi->chip_select] = 1; |
308 | } else if (bits_per_word <= 16 && bits_per_word >= 2) { | 308 | } else if (bits_per_word <= 16 && bits_per_word >= 2) { |
309 | davinci_spi->get_rx = davinci_spi_rx_buf_u16; | 309 | dspi->get_rx = davinci_spi_rx_buf_u16; |
310 | davinci_spi->get_tx = davinci_spi_tx_buf_u16; | 310 | dspi->get_tx = davinci_spi_tx_buf_u16; |
311 | davinci_spi->bytes_per_word[spi->chip_select] = 2; | 311 | dspi->bytes_per_word[spi->chip_select] = 2; |
312 | } else | 312 | } else |
313 | return -EINVAL; | 313 | return -EINVAL; |
314 | 314 | ||
@@ -317,7 +317,7 @@ static int davinci_spi_setup_transfer(struct spi_device *spi, | |||
317 | 317 | ||
318 | /* Set up SPIFMTn register, unique to this chipselect. */ | 318 | /* Set up SPIFMTn register, unique to this chipselect. */ |
319 | 319 | ||
320 | prescale = davinci_spi_get_prescale(davinci_spi, hz); | 320 | prescale = davinci_spi_get_prescale(dspi, hz); |
321 | if (prescale < 0) | 321 | if (prescale < 0) |
322 | return prescale; | 322 | return prescale; |
323 | 323 | ||
@@ -345,7 +345,7 @@ static int davinci_spi_setup_transfer(struct spi_device *spi, | |||
345 | * - 4 pin with enable is (SPI_READY | SPI_NO_CS) | 345 | * - 4 pin with enable is (SPI_READY | SPI_NO_CS) |
346 | */ | 346 | */ |
347 | 347 | ||
348 | if (davinci_spi->version == SPI_VERSION_2) { | 348 | if (dspi->version == SPI_VERSION_2) { |
349 | 349 | ||
350 | u32 delay = 0; | 350 | u32 delay = 0; |
351 | 351 | ||
@@ -375,10 +375,10 @@ static int davinci_spi_setup_transfer(struct spi_device *spi, | |||
375 | & SPIDELAY_C2EDELAY_MASK; | 375 | & SPIDELAY_C2EDELAY_MASK; |
376 | } | 376 | } |
377 | 377 | ||
378 | iowrite32(delay, davinci_spi->base + SPIDELAY); | 378 | iowrite32(delay, dspi->base + SPIDELAY); |
379 | } | 379 | } |
380 | 380 | ||
381 | iowrite32(spifmt, davinci_spi->base + SPIFMT0); | 381 | iowrite32(spifmt, dspi->base + SPIFMT0); |
382 | 382 | ||
383 | return 0; | 383 | return 0; |
384 | } | 384 | } |
@@ -392,11 +392,11 @@ static int davinci_spi_setup_transfer(struct spi_device *spi, | |||
392 | static int davinci_spi_setup(struct spi_device *spi) | 392 | static int davinci_spi_setup(struct spi_device *spi) |
393 | { | 393 | { |
394 | int retval = 0; | 394 | int retval = 0; |
395 | struct davinci_spi *davinci_spi; | 395 | struct davinci_spi *dspi; |
396 | struct davinci_spi_platform_data *pdata; | 396 | struct davinci_spi_platform_data *pdata; |
397 | 397 | ||
398 | davinci_spi = spi_master_get_devdata(spi->master); | 398 | dspi = spi_master_get_devdata(spi->master); |
399 | pdata = davinci_spi->pdata; | 399 | pdata = dspi->pdata; |
400 | 400 | ||
401 | /* if bits per word length is zero then set it default 8 */ | 401 | /* if bits per word length is zero then set it default 8 */ |
402 | if (!spi->bits_per_word) | 402 | if (!spi->bits_per_word) |
@@ -405,28 +405,24 @@ static int davinci_spi_setup(struct spi_device *spi) | |||
405 | if (!(spi->mode & SPI_NO_CS)) { | 405 | if (!(spi->mode & SPI_NO_CS)) { |
406 | if ((pdata->chip_sel == NULL) || | 406 | if ((pdata->chip_sel == NULL) || |
407 | (pdata->chip_sel[spi->chip_select] == SPI_INTERN_CS)) | 407 | (pdata->chip_sel[spi->chip_select] == SPI_INTERN_CS)) |
408 | set_io_bits(davinci_spi->base + SPIPC0, | 408 | set_io_bits(dspi->base + SPIPC0, 1 << spi->chip_select); |
409 | 1 << spi->chip_select); | ||
410 | 409 | ||
411 | } | 410 | } |
412 | 411 | ||
413 | if (spi->mode & SPI_READY) | 412 | if (spi->mode & SPI_READY) |
414 | set_io_bits(davinci_spi->base + SPIPC0, SPIPC0_SPIENA_MASK); | 413 | set_io_bits(dspi->base + SPIPC0, SPIPC0_SPIENA_MASK); |
415 | 414 | ||
416 | if (spi->mode & SPI_LOOP) | 415 | if (spi->mode & SPI_LOOP) |
417 | set_io_bits(davinci_spi->base + SPIGCR1, | 416 | set_io_bits(dspi->base + SPIGCR1, SPIGCR1_LOOPBACK_MASK); |
418 | SPIGCR1_LOOPBACK_MASK); | ||
419 | else | 417 | else |
420 | clear_io_bits(davinci_spi->base + SPIGCR1, | 418 | clear_io_bits(dspi->base + SPIGCR1, SPIGCR1_LOOPBACK_MASK); |
421 | SPIGCR1_LOOPBACK_MASK); | ||
422 | 419 | ||
423 | return retval; | 420 | return retval; |
424 | } | 421 | } |
425 | 422 | ||
426 | static int davinci_spi_check_error(struct davinci_spi *davinci_spi, | 423 | static int davinci_spi_check_error(struct davinci_spi *dspi, int int_status) |
427 | int int_status) | ||
428 | { | 424 | { |
429 | struct device *sdev = davinci_spi->bitbang.master->dev.parent; | 425 | struct device *sdev = dspi->bitbang.master->dev.parent; |
430 | 426 | ||
431 | if (int_status & SPIFLG_TIMEOUT_MASK) { | 427 | if (int_status & SPIFLG_TIMEOUT_MASK) { |
432 | dev_dbg(sdev, "SPI Time-out Error\n"); | 428 | dev_dbg(sdev, "SPI Time-out Error\n"); |
@@ -441,7 +437,7 @@ static int davinci_spi_check_error(struct davinci_spi *davinci_spi, | |||
441 | return -EIO; | 437 | return -EIO; |
442 | } | 438 | } |
443 | 439 | ||
444 | if (davinci_spi->version == SPI_VERSION_2) { | 440 | if (dspi->version == SPI_VERSION_2) { |
445 | if (int_status & SPIFLG_DLEN_ERR_MASK) { | 441 | if (int_status & SPIFLG_DLEN_ERR_MASK) { |
446 | dev_dbg(sdev, "SPI Data Length Error\n"); | 442 | dev_dbg(sdev, "SPI Data Length Error\n"); |
447 | return -EIO; | 443 | return -EIO; |
@@ -465,35 +461,35 @@ static int davinci_spi_check_error(struct davinci_spi *davinci_spi, | |||
465 | 461 | ||
466 | /** | 462 | /** |
467 | * davinci_spi_process_events - check for and handle any SPI controller events | 463 | * davinci_spi_process_events - check for and handle any SPI controller events |
468 | * @davinci_spi: the controller data | 464 | * @dspi: the controller data |
469 | * | 465 | * |
470 | * This function will check the SPIFLG register and handle any events that are | 466 | * This function will check the SPIFLG register and handle any events that are |
471 | * detected there | 467 | * detected there |
472 | */ | 468 | */ |
473 | static int davinci_spi_process_events(struct davinci_spi *davinci_spi) | 469 | static int davinci_spi_process_events(struct davinci_spi *dspi) |
474 | { | 470 | { |
475 | u32 buf, status, errors = 0, data1_reg_val; | 471 | u32 buf, status, errors = 0, spidat1; |
476 | 472 | ||
477 | buf = ioread32(davinci_spi->base + SPIBUF); | 473 | buf = ioread32(dspi->base + SPIBUF); |
478 | 474 | ||
479 | if (davinci_spi->rcount > 0 && !(buf & SPIBUF_RXEMPTY_MASK)) { | 475 | if (dspi->rcount > 0 && !(buf & SPIBUF_RXEMPTY_MASK)) { |
480 | davinci_spi->get_rx(buf & 0xFFFF, davinci_spi); | 476 | dspi->get_rx(buf & 0xFFFF, dspi); |
481 | davinci_spi->rcount--; | 477 | dspi->rcount--; |
482 | } | 478 | } |
483 | 479 | ||
484 | status = ioread32(davinci_spi->base + SPIFLG); | 480 | status = ioread32(dspi->base + SPIFLG); |
485 | 481 | ||
486 | if (unlikely(status & SPIFLG_ERROR_MASK)) { | 482 | if (unlikely(status & SPIFLG_ERROR_MASK)) { |
487 | errors = status & SPIFLG_ERROR_MASK; | 483 | errors = status & SPIFLG_ERROR_MASK; |
488 | goto out; | 484 | goto out; |
489 | } | 485 | } |
490 | 486 | ||
491 | if (davinci_spi->wcount > 0 && !(buf & SPIBUF_TXFULL_MASK)) { | 487 | if (dspi->wcount > 0 && !(buf & SPIBUF_TXFULL_MASK)) { |
492 | data1_reg_val = ioread32(davinci_spi->base + SPIDAT1); | 488 | spidat1 = ioread32(dspi->base + SPIDAT1); |
493 | davinci_spi->wcount--; | 489 | dspi->wcount--; |
494 | data1_reg_val &= ~0xFFFF; | 490 | spidat1 &= ~0xFFFF; |
495 | data1_reg_val |= 0xFFFF & davinci_spi->get_tx(davinci_spi); | 491 | spidat1 |= 0xFFFF & dspi->get_tx(dspi); |
496 | iowrite32(data1_reg_val, davinci_spi->base + SPIDAT1); | 492 | iowrite32(spidat1, dspi->base + SPIDAT1); |
497 | } | 493 | } |
498 | 494 | ||
499 | out: | 495 | out: |
@@ -502,21 +498,20 @@ out: | |||
502 | 498 | ||
503 | static void davinci_spi_dma_callback(unsigned lch, u16 status, void *data) | 499 | static void davinci_spi_dma_callback(unsigned lch, u16 status, void *data) |
504 | { | 500 | { |
505 | struct davinci_spi *davinci_spi = data; | 501 | struct davinci_spi *dspi = data; |
506 | struct davinci_spi_dma *davinci_spi_dma = &davinci_spi->dma_channels; | 502 | struct davinci_spi_dma *dma = &dspi->dma; |
507 | 503 | ||
508 | edma_stop(lch); | 504 | edma_stop(lch); |
509 | 505 | ||
510 | if (status == DMA_COMPLETE) { | 506 | if (status == DMA_COMPLETE) { |
511 | if (lch == davinci_spi_dma->dma_rx_channel) | 507 | if (lch == dma->rx_channel) |
512 | davinci_spi->rcount = 0; | 508 | dspi->rcount = 0; |
513 | if (lch == davinci_spi_dma->dma_tx_channel) | 509 | if (lch == dma->tx_channel) |
514 | davinci_spi->wcount = 0; | 510 | dspi->wcount = 0; |
515 | } | 511 | } |
516 | 512 | ||
517 | if ((!davinci_spi->wcount && !davinci_spi->rcount) || | 513 | if ((!dspi->wcount && !dspi->rcount) || (status != DMA_COMPLETE)) |
518 | (status != DMA_COMPLETE)) | 514 | complete(&dspi->done); |
519 | complete(&davinci_spi->done); | ||
520 | } | 515 | } |
521 | 516 | ||
522 | /** | 517 | /** |
@@ -530,57 +525,57 @@ static void davinci_spi_dma_callback(unsigned lch, u16 status, void *data) | |||
530 | */ | 525 | */ |
531 | static int davinci_spi_bufs(struct spi_device *spi, struct spi_transfer *t) | 526 | static int davinci_spi_bufs(struct spi_device *spi, struct spi_transfer *t) |
532 | { | 527 | { |
533 | struct davinci_spi *davinci_spi; | 528 | struct davinci_spi *dspi; |
534 | int data_type, ret; | 529 | int data_type, ret; |
535 | u32 tx_data, data1_reg_val; | 530 | u32 tx_data, spidat1; |
536 | u32 errors = 0; | 531 | u32 errors = 0; |
537 | struct davinci_spi_config *spicfg; | 532 | struct davinci_spi_config *spicfg; |
538 | struct davinci_spi_platform_data *pdata; | 533 | struct davinci_spi_platform_data *pdata; |
539 | unsigned uninitialized_var(rx_buf_count); | 534 | unsigned uninitialized_var(rx_buf_count); |
540 | struct device *sdev; | 535 | struct device *sdev; |
541 | 536 | ||
542 | davinci_spi = spi_master_get_devdata(spi->master); | 537 | dspi = spi_master_get_devdata(spi->master); |
543 | pdata = davinci_spi->pdata; | 538 | pdata = dspi->pdata; |
544 | spicfg = (struct davinci_spi_config *)spi->controller_data; | 539 | spicfg = (struct davinci_spi_config *)spi->controller_data; |
545 | if (!spicfg) | 540 | if (!spicfg) |
546 | spicfg = &davinci_spi_default_cfg; | 541 | spicfg = &davinci_spi_default_cfg; |
547 | sdev = davinci_spi->bitbang.master->dev.parent; | 542 | sdev = dspi->bitbang.master->dev.parent; |
548 | 543 | ||
549 | /* convert len to words based on bits_per_word */ | 544 | /* convert len to words based on bits_per_word */ |
550 | data_type = davinci_spi->bytes_per_word[spi->chip_select]; | 545 | data_type = dspi->bytes_per_word[spi->chip_select]; |
551 | 546 | ||
552 | davinci_spi->tx = t->tx_buf; | 547 | dspi->tx = t->tx_buf; |
553 | davinci_spi->rx = t->rx_buf; | 548 | dspi->rx = t->rx_buf; |
554 | davinci_spi->wcount = t->len / data_type; | 549 | dspi->wcount = t->len / data_type; |
555 | davinci_spi->rcount = davinci_spi->wcount; | 550 | dspi->rcount = dspi->wcount; |
556 | 551 | ||
557 | data1_reg_val = ioread32(davinci_spi->base + SPIDAT1); | 552 | spidat1 = ioread32(dspi->base + SPIDAT1); |
558 | 553 | ||
559 | clear_io_bits(davinci_spi->base + SPIGCR1, SPIGCR1_POWERDOWN_MASK); | 554 | clear_io_bits(dspi->base + SPIGCR1, SPIGCR1_POWERDOWN_MASK); |
560 | set_io_bits(davinci_spi->base + SPIGCR1, SPIGCR1_SPIENA_MASK); | 555 | set_io_bits(dspi->base + SPIGCR1, SPIGCR1_SPIENA_MASK); |
561 | 556 | ||
562 | INIT_COMPLETION(davinci_spi->done); | 557 | INIT_COMPLETION(dspi->done); |
563 | 558 | ||
564 | if (spicfg->io_type == SPI_IO_TYPE_INTR) | 559 | if (spicfg->io_type == SPI_IO_TYPE_INTR) |
565 | set_io_bits(davinci_spi->base + SPIINT, SPIINT_MASKINT); | 560 | set_io_bits(dspi->base + SPIINT, SPIINT_MASKINT); |
566 | 561 | ||
567 | if (spicfg->io_type != SPI_IO_TYPE_DMA) { | 562 | if (spicfg->io_type != SPI_IO_TYPE_DMA) { |
568 | /* start the transfer */ | 563 | /* start the transfer */ |
569 | davinci_spi->wcount--; | 564 | dspi->wcount--; |
570 | tx_data = davinci_spi->get_tx(davinci_spi); | 565 | tx_data = dspi->get_tx(dspi); |
571 | data1_reg_val &= 0xFFFF0000; | 566 | spidat1 &= 0xFFFF0000; |
572 | data1_reg_val |= tx_data & 0xFFFF; | 567 | spidat1 |= tx_data & 0xFFFF; |
573 | iowrite32(data1_reg_val, davinci_spi->base + SPIDAT1); | 568 | iowrite32(spidat1, dspi->base + SPIDAT1); |
574 | } else { | 569 | } else { |
575 | struct davinci_spi_dma *davinci_spi_dma; | 570 | struct davinci_spi_dma *dma; |
576 | unsigned long tx_reg, rx_reg; | 571 | unsigned long tx_reg, rx_reg; |
577 | struct edmacc_param param; | 572 | struct edmacc_param param; |
578 | void *rx_buf; | 573 | void *rx_buf; |
579 | 574 | ||
580 | davinci_spi_dma = &davinci_spi->dma_channels; | 575 | dma = &dspi->dma; |
581 | 576 | ||
582 | tx_reg = (unsigned long)davinci_spi->pbase + SPIDAT1; | 577 | tx_reg = (unsigned long)dspi->pbase + SPIDAT1; |
583 | rx_reg = (unsigned long)davinci_spi->pbase + SPIBUF; | 578 | rx_reg = (unsigned long)dspi->pbase + SPIBUF; |
584 | 579 | ||
585 | /* | 580 | /* |
586 | * Transmit DMA setup | 581 | * Transmit DMA setup |
@@ -596,26 +591,24 @@ static int davinci_spi_bufs(struct spi_device *spi, struct spi_transfer *t) | |||
596 | 591 | ||
597 | if (t->tx_buf) { | 592 | if (t->tx_buf) { |
598 | t->tx_dma = dma_map_single(&spi->dev, (void *)t->tx_buf, | 593 | t->tx_dma = dma_map_single(&spi->dev, (void *)t->tx_buf, |
599 | davinci_spi->wcount, DMA_TO_DEVICE); | 594 | dspi->wcount, DMA_TO_DEVICE); |
600 | if (dma_mapping_error(&spi->dev, t->tx_dma)) { | 595 | if (dma_mapping_error(&spi->dev, t->tx_dma)) { |
601 | dev_dbg(sdev, "Unable to DMA map %d bytes" | 596 | dev_dbg(sdev, "Unable to DMA map %d bytes" |
602 | "TX buffer\n", | 597 | "TX buffer\n", dspi->wcount); |
603 | davinci_spi->wcount); | ||
604 | return -ENOMEM; | 598 | return -ENOMEM; |
605 | } | 599 | } |
606 | } | 600 | } |
607 | 601 | ||
608 | param.opt = TCINTEN | EDMA_TCC(davinci_spi_dma->dma_tx_channel); | 602 | param.opt = TCINTEN | EDMA_TCC(dma->tx_channel); |
609 | param.src = t->tx_buf ? t->tx_dma : tx_reg; | 603 | param.src = t->tx_buf ? t->tx_dma : tx_reg; |
610 | param.a_b_cnt = davinci_spi->wcount << 16 | data_type; | 604 | param.a_b_cnt = dspi->wcount << 16 | data_type; |
611 | param.dst = tx_reg; | 605 | param.dst = tx_reg; |
612 | param.src_dst_bidx = t->tx_buf ? data_type : 0; | 606 | param.src_dst_bidx = t->tx_buf ? data_type : 0; |
613 | param.link_bcntrld = 0xffff; | 607 | param.link_bcntrld = 0xffff; |
614 | param.src_dst_cidx = 0; | 608 | param.src_dst_cidx = 0; |
615 | param.ccnt = 1; | 609 | param.ccnt = 1; |
616 | edma_write_slot(davinci_spi_dma->dma_tx_channel, ¶m); | 610 | edma_write_slot(dma->tx_channel, ¶m); |
617 | edma_link(davinci_spi_dma->dma_tx_channel, | 611 | edma_link(dma->tx_channel, dma->dummy_param_slot); |
618 | davinci_spi_dma->dummy_param_slot); | ||
619 | 612 | ||
620 | /* | 613 | /* |
621 | * Receive DMA setup | 614 | * Receive DMA setup |
@@ -631,10 +624,10 @@ static int davinci_spi_bufs(struct spi_device *spi, struct spi_transfer *t) | |||
631 | 624 | ||
632 | if (t->rx_buf) { | 625 | if (t->rx_buf) { |
633 | rx_buf = t->rx_buf; | 626 | rx_buf = t->rx_buf; |
634 | rx_buf_count = davinci_spi->rcount; | 627 | rx_buf_count = dspi->rcount; |
635 | } else { | 628 | } else { |
636 | rx_buf = davinci_spi->rx_tmp_buf; | 629 | rx_buf = dspi->rx_tmp_buf; |
637 | rx_buf_count = sizeof(davinci_spi->rx_tmp_buf); | 630 | rx_buf_count = sizeof(dspi->rx_tmp_buf); |
638 | } | 631 | } |
639 | 632 | ||
640 | t->rx_dma = dma_map_single(&spi->dev, rx_buf, rx_buf_count, | 633 | t->rx_dma = dma_map_single(&spi->dev, rx_buf, rx_buf_count, |
@@ -643,71 +636,69 @@ static int davinci_spi_bufs(struct spi_device *spi, struct spi_transfer *t) | |||
643 | dev_dbg(sdev, "Couldn't DMA map a %d bytes RX buffer\n", | 636 | dev_dbg(sdev, "Couldn't DMA map a %d bytes RX buffer\n", |
644 | rx_buf_count); | 637 | rx_buf_count); |
645 | if (t->tx_buf) | 638 | if (t->tx_buf) |
646 | dma_unmap_single(NULL, t->tx_dma, | 639 | dma_unmap_single(NULL, t->tx_dma, dspi->wcount, |
647 | davinci_spi->wcount, | 640 | DMA_TO_DEVICE); |
648 | DMA_TO_DEVICE); | ||
649 | return -ENOMEM; | 641 | return -ENOMEM; |
650 | } | 642 | } |
651 | 643 | ||
652 | param.opt = TCINTEN | EDMA_TCC(davinci_spi_dma->dma_rx_channel); | 644 | param.opt = TCINTEN | EDMA_TCC(dma->rx_channel); |
653 | param.src = rx_reg; | 645 | param.src = rx_reg; |
654 | param.a_b_cnt = davinci_spi->rcount << 16 | data_type; | 646 | param.a_b_cnt = dspi->rcount << 16 | data_type; |
655 | param.dst = t->rx_dma; | 647 | param.dst = t->rx_dma; |
656 | param.src_dst_bidx = (t->rx_buf ? data_type : 0) << 16; | 648 | param.src_dst_bidx = (t->rx_buf ? data_type : 0) << 16; |
657 | param.link_bcntrld = 0xffff; | 649 | param.link_bcntrld = 0xffff; |
658 | param.src_dst_cidx = 0; | 650 | param.src_dst_cidx = 0; |
659 | param.ccnt = 1; | 651 | param.ccnt = 1; |
660 | edma_write_slot(davinci_spi_dma->dma_rx_channel, ¶m); | 652 | edma_write_slot(dma->rx_channel, ¶m); |
661 | 653 | ||
662 | if (pdata->cshold_bug) | 654 | if (pdata->cshold_bug) |
663 | iowrite16(data1_reg_val >> 16, | 655 | iowrite16(spidat1 >> 16, dspi->base + SPIDAT1 + 2); |
664 | davinci_spi->base + SPIDAT1 + 2); | ||
665 | 656 | ||
666 | edma_start(davinci_spi_dma->dma_rx_channel); | 657 | edma_start(dma->rx_channel); |
667 | edma_start(davinci_spi_dma->dma_tx_channel); | 658 | edma_start(dma->tx_channel); |
668 | set_io_bits(davinci_spi->base + SPIINT, SPIINT_DMA_REQ_EN); | 659 | set_io_bits(dspi->base + SPIINT, SPIINT_DMA_REQ_EN); |
669 | } | 660 | } |
670 | 661 | ||
671 | /* Wait for the transfer to complete */ | 662 | /* Wait for the transfer to complete */ |
672 | if (spicfg->io_type != SPI_IO_TYPE_POLL) { | 663 | if (spicfg->io_type != SPI_IO_TYPE_POLL) { |
673 | wait_for_completion_interruptible(&(davinci_spi->done)); | 664 | wait_for_completion_interruptible(&(dspi->done)); |
674 | } else { | 665 | } else { |
675 | while (davinci_spi->rcount > 0 || davinci_spi->wcount > 0) { | 666 | while (dspi->rcount > 0 || dspi->wcount > 0) { |
676 | errors = davinci_spi_process_events(davinci_spi); | 667 | errors = davinci_spi_process_events(dspi); |
677 | if (errors) | 668 | if (errors) |
678 | break; | 669 | break; |
679 | cpu_relax(); | 670 | cpu_relax(); |
680 | } | 671 | } |
681 | } | 672 | } |
682 | 673 | ||
683 | clear_io_bits(davinci_spi->base + SPIINT, SPIINT_MASKALL); | 674 | clear_io_bits(dspi->base + SPIINT, SPIINT_MASKALL); |
684 | if (spicfg->io_type == SPI_IO_TYPE_DMA) { | 675 | if (spicfg->io_type == SPI_IO_TYPE_DMA) { |
685 | 676 | ||
686 | if (t->tx_buf) | 677 | if (t->tx_buf) |
687 | dma_unmap_single(NULL, t->tx_dma, davinci_spi->wcount, | 678 | dma_unmap_single(NULL, t->tx_dma, dspi->wcount, |
688 | DMA_TO_DEVICE); | 679 | DMA_TO_DEVICE); |
689 | 680 | ||
690 | dma_unmap_single(NULL, t->rx_dma, rx_buf_count, | 681 | dma_unmap_single(NULL, t->rx_dma, rx_buf_count, |
691 | DMA_FROM_DEVICE); | 682 | DMA_FROM_DEVICE); |
692 | 683 | ||
693 | clear_io_bits(davinci_spi->base + SPIINT, SPIINT_DMA_REQ_EN); | 684 | clear_io_bits(dspi->base + SPIINT, SPIINT_DMA_REQ_EN); |
694 | } | 685 | } |
695 | 686 | ||
696 | clear_io_bits(davinci_spi->base + SPIGCR1, SPIGCR1_SPIENA_MASK); | 687 | clear_io_bits(dspi->base + SPIGCR1, SPIGCR1_SPIENA_MASK); |
697 | set_io_bits(davinci_spi->base + SPIGCR1, SPIGCR1_POWERDOWN_MASK); | 688 | set_io_bits(dspi->base + SPIGCR1, SPIGCR1_POWERDOWN_MASK); |
698 | 689 | ||
699 | /* | 690 | /* |
700 | * Check for bit error, desync error,parity error,timeout error and | 691 | * Check for bit error, desync error,parity error,timeout error and |
701 | * receive overflow errors | 692 | * receive overflow errors |
702 | */ | 693 | */ |
703 | if (errors) { | 694 | if (errors) { |
704 | ret = davinci_spi_check_error(davinci_spi, errors); | 695 | ret = davinci_spi_check_error(dspi, errors); |
705 | WARN(!ret, "%s: error reported but no error found!\n", | 696 | WARN(!ret, "%s: error reported but no error found!\n", |
706 | dev_name(&spi->dev)); | 697 | dev_name(&spi->dev)); |
707 | return ret; | 698 | return ret; |
708 | } | 699 | } |
709 | 700 | ||
710 | if (davinci_spi->rcount != 0 || davinci_spi->wcount != 0) { | 701 | if (dspi->rcount != 0 || dspi->wcount != 0) { |
711 | dev_err(sdev, "SPI data transfer error\n"); | 702 | dev_err(sdev, "SPI data transfer error\n"); |
712 | return -EIO; | 703 | return -EIO; |
713 | } | 704 | } |
@@ -726,60 +717,56 @@ static int davinci_spi_bufs(struct spi_device *spi, struct spi_transfer *t) | |||
726 | * If transfer length is zero then it will indicate the COMPLETION so that | 717 | * If transfer length is zero then it will indicate the COMPLETION so that |
727 | * davinci_spi_bufs function can go ahead. | 718 | * davinci_spi_bufs function can go ahead. |
728 | */ | 719 | */ |
729 | static irqreturn_t davinci_spi_irq(s32 irq, void *context_data) | 720 | static irqreturn_t davinci_spi_irq(s32 irq, void *data) |
730 | { | 721 | { |
731 | struct davinci_spi *davinci_spi = context_data; | 722 | struct davinci_spi *dspi = data; |
732 | int status; | 723 | int status; |
733 | 724 | ||
734 | status = davinci_spi_process_events(davinci_spi); | 725 | status = davinci_spi_process_events(dspi); |
735 | if (unlikely(status != 0)) | 726 | if (unlikely(status != 0)) |
736 | clear_io_bits(davinci_spi->base + SPIINT, SPIINT_MASKINT); | 727 | clear_io_bits(dspi->base + SPIINT, SPIINT_MASKINT); |
737 | 728 | ||
738 | if ((!davinci_spi->rcount && !davinci_spi->wcount) || status) | 729 | if ((!dspi->rcount && !dspi->wcount) || status) |
739 | complete(&davinci_spi->done); | 730 | complete(&dspi->done); |
740 | 731 | ||
741 | return IRQ_HANDLED; | 732 | return IRQ_HANDLED; |
742 | } | 733 | } |
743 | 734 | ||
744 | static int davinci_spi_request_dma(struct davinci_spi *davinci_spi) | 735 | static int davinci_spi_request_dma(struct davinci_spi *dspi) |
745 | { | 736 | { |
746 | int r; | 737 | int r; |
747 | struct davinci_spi_dma *davinci_spi_dma = &davinci_spi->dma_channels; | 738 | struct davinci_spi_dma *dma = &dspi->dma; |
748 | 739 | ||
749 | r = edma_alloc_channel(davinci_spi_dma->dma_rx_channel, | 740 | r = edma_alloc_channel(dma->rx_channel, davinci_spi_dma_callback, dspi, |
750 | davinci_spi_dma_callback, davinci_spi, | 741 | dma->eventq); |
751 | davinci_spi_dma->eventq); | ||
752 | if (r < 0) { | 742 | if (r < 0) { |
753 | pr_err("Unable to request DMA channel for SPI RX\n"); | 743 | pr_err("Unable to request DMA channel for SPI RX\n"); |
754 | r = -EAGAIN; | 744 | r = -EAGAIN; |
755 | goto rx_dma_failed; | 745 | goto rx_dma_failed; |
756 | } | 746 | } |
757 | 747 | ||
758 | r = edma_alloc_channel(davinci_spi_dma->dma_tx_channel, | 748 | r = edma_alloc_channel(dma->tx_channel, davinci_spi_dma_callback, dspi, |
759 | davinci_spi_dma_callback, davinci_spi, | 749 | dma->eventq); |
760 | davinci_spi_dma->eventq); | ||
761 | if (r < 0) { | 750 | if (r < 0) { |
762 | pr_err("Unable to request DMA channel for SPI TX\n"); | 751 | pr_err("Unable to request DMA channel for SPI TX\n"); |
763 | r = -EAGAIN; | 752 | r = -EAGAIN; |
764 | goto tx_dma_failed; | 753 | goto tx_dma_failed; |
765 | } | 754 | } |
766 | 755 | ||
767 | r = edma_alloc_slot(EDMA_CTLR(davinci_spi_dma->dma_tx_channel), | 756 | r = edma_alloc_slot(EDMA_CTLR(dma->tx_channel), EDMA_SLOT_ANY); |
768 | EDMA_SLOT_ANY); | ||
769 | if (r < 0) { | 757 | if (r < 0) { |
770 | pr_err("Unable to request SPI TX DMA param slot\n"); | 758 | pr_err("Unable to request SPI TX DMA param slot\n"); |
771 | r = -EAGAIN; | 759 | r = -EAGAIN; |
772 | goto param_failed; | 760 | goto param_failed; |
773 | } | 761 | } |
774 | davinci_spi_dma->dummy_param_slot = r; | 762 | dma->dummy_param_slot = r; |
775 | edma_link(davinci_spi_dma->dummy_param_slot, | 763 | edma_link(dma->dummy_param_slot, dma->dummy_param_slot); |
776 | davinci_spi_dma->dummy_param_slot); | ||
777 | 764 | ||
778 | return 0; | 765 | return 0; |
779 | param_failed: | 766 | param_failed: |
780 | edma_free_channel(davinci_spi_dma->dma_tx_channel); | 767 | edma_free_channel(dma->tx_channel); |
781 | tx_dma_failed: | 768 | tx_dma_failed: |
782 | edma_free_channel(davinci_spi_dma->dma_rx_channel); | 769 | edma_free_channel(dma->rx_channel); |
783 | rx_dma_failed: | 770 | rx_dma_failed: |
784 | return r; | 771 | return r; |
785 | } | 772 | } |
@@ -798,7 +785,7 @@ rx_dma_failed: | |||
798 | static int davinci_spi_probe(struct platform_device *pdev) | 785 | static int davinci_spi_probe(struct platform_device *pdev) |
799 | { | 786 | { |
800 | struct spi_master *master; | 787 | struct spi_master *master; |
801 | struct davinci_spi *davinci_spi; | 788 | struct davinci_spi *dspi; |
802 | struct davinci_spi_platform_data *pdata; | 789 | struct davinci_spi_platform_data *pdata; |
803 | struct resource *r, *mem; | 790 | struct resource *r, *mem; |
804 | resource_size_t dma_rx_chan = SPI_NO_RESOURCE; | 791 | resource_size_t dma_rx_chan = SPI_NO_RESOURCE; |
@@ -821,8 +808,8 @@ static int davinci_spi_probe(struct platform_device *pdev) | |||
821 | 808 | ||
822 | dev_set_drvdata(&pdev->dev, master); | 809 | dev_set_drvdata(&pdev->dev, master); |
823 | 810 | ||
824 | davinci_spi = spi_master_get_devdata(master); | 811 | dspi = spi_master_get_devdata(master); |
825 | if (davinci_spi == NULL) { | 812 | if (dspi == NULL) { |
826 | ret = -ENOENT; | 813 | ret = -ENOENT; |
827 | goto free_master; | 814 | goto free_master; |
828 | } | 815 | } |
@@ -833,8 +820,8 @@ static int davinci_spi_probe(struct platform_device *pdev) | |||
833 | goto free_master; | 820 | goto free_master; |
834 | } | 821 | } |
835 | 822 | ||
836 | davinci_spi->pbase = r->start; | 823 | dspi->pbase = r->start; |
837 | davinci_spi->pdata = pdata; | 824 | dspi->pdata = pdata; |
838 | 825 | ||
839 | mem = request_mem_region(r->start, resource_size(r), pdev->name); | 826 | mem = request_mem_region(r->start, resource_size(r), pdev->name); |
840 | if (mem == NULL) { | 827 | if (mem == NULL) { |
@@ -842,48 +829,48 @@ static int davinci_spi_probe(struct platform_device *pdev) | |||
842 | goto free_master; | 829 | goto free_master; |
843 | } | 830 | } |
844 | 831 | ||
845 | davinci_spi->base = ioremap(r->start, resource_size(r)); | 832 | dspi->base = ioremap(r->start, resource_size(r)); |
846 | if (davinci_spi->base == NULL) { | 833 | if (dspi->base == NULL) { |
847 | ret = -ENOMEM; | 834 | ret = -ENOMEM; |
848 | goto release_region; | 835 | goto release_region; |
849 | } | 836 | } |
850 | 837 | ||
851 | davinci_spi->irq = platform_get_irq(pdev, 0); | 838 | dspi->irq = platform_get_irq(pdev, 0); |
852 | if (davinci_spi->irq <= 0) { | 839 | if (dspi->irq <= 0) { |
853 | ret = -EINVAL; | 840 | ret = -EINVAL; |
854 | goto unmap_io; | 841 | goto unmap_io; |
855 | } | 842 | } |
856 | 843 | ||
857 | ret = request_irq(davinci_spi->irq, davinci_spi_irq, 0, | 844 | ret = request_irq(dspi->irq, davinci_spi_irq, 0, dev_name(&pdev->dev), |
858 | dev_name(&pdev->dev), davinci_spi); | 845 | dspi); |
859 | if (ret) | 846 | if (ret) |
860 | goto unmap_io; | 847 | goto unmap_io; |
861 | 848 | ||
862 | davinci_spi->bitbang.master = spi_master_get(master); | 849 | dspi->bitbang.master = spi_master_get(master); |
863 | if (davinci_spi->bitbang.master == NULL) { | 850 | if (dspi->bitbang.master == NULL) { |
864 | ret = -ENODEV; | 851 | ret = -ENODEV; |
865 | goto irq_free; | 852 | goto irq_free; |
866 | } | 853 | } |
867 | 854 | ||
868 | davinci_spi->clk = clk_get(&pdev->dev, NULL); | 855 | dspi->clk = clk_get(&pdev->dev, NULL); |
869 | if (IS_ERR(davinci_spi->clk)) { | 856 | if (IS_ERR(dspi->clk)) { |
870 | ret = -ENODEV; | 857 | ret = -ENODEV; |
871 | goto put_master; | 858 | goto put_master; |
872 | } | 859 | } |
873 | clk_enable(davinci_spi->clk); | 860 | clk_enable(dspi->clk); |
874 | 861 | ||
875 | master->bus_num = pdev->id; | 862 | master->bus_num = pdev->id; |
876 | master->num_chipselect = pdata->num_chipselect; | 863 | master->num_chipselect = pdata->num_chipselect; |
877 | master->setup = davinci_spi_setup; | 864 | master->setup = davinci_spi_setup; |
878 | 865 | ||
879 | davinci_spi->bitbang.chipselect = davinci_spi_chipselect; | 866 | dspi->bitbang.chipselect = davinci_spi_chipselect; |
880 | davinci_spi->bitbang.setup_transfer = davinci_spi_setup_transfer; | 867 | dspi->bitbang.setup_transfer = davinci_spi_setup_transfer; |
881 | 868 | ||
882 | davinci_spi->version = pdata->version; | 869 | dspi->version = pdata->version; |
883 | 870 | ||
884 | davinci_spi->bitbang.flags = SPI_NO_CS | SPI_LSB_FIRST | SPI_LOOP; | 871 | dspi->bitbang.flags = SPI_NO_CS | SPI_LSB_FIRST | SPI_LOOP; |
885 | if (davinci_spi->version == SPI_VERSION_2) | 872 | if (dspi->version == SPI_VERSION_2) |
886 | davinci_spi->bitbang.flags |= SPI_READY; | 873 | dspi->bitbang.flags |= SPI_READY; |
887 | 874 | ||
888 | r = platform_get_resource(pdev, IORESOURCE_DMA, 0); | 875 | r = platform_get_resource(pdev, IORESOURCE_DMA, 0); |
889 | if (r) | 876 | if (r) |
@@ -895,15 +882,15 @@ static int davinci_spi_probe(struct platform_device *pdev) | |||
895 | if (r) | 882 | if (r) |
896 | dma_eventq = r->start; | 883 | dma_eventq = r->start; |
897 | 884 | ||
898 | davinci_spi->bitbang.txrx_bufs = davinci_spi_bufs; | 885 | dspi->bitbang.txrx_bufs = davinci_spi_bufs; |
899 | if (dma_rx_chan != SPI_NO_RESOURCE && | 886 | if (dma_rx_chan != SPI_NO_RESOURCE && |
900 | dma_tx_chan != SPI_NO_RESOURCE && | 887 | dma_tx_chan != SPI_NO_RESOURCE && |
901 | dma_eventq != SPI_NO_RESOURCE) { | 888 | dma_eventq != SPI_NO_RESOURCE) { |
902 | davinci_spi->dma_channels.dma_rx_channel = dma_rx_chan; | 889 | dspi->dma.rx_channel = dma_rx_chan; |
903 | davinci_spi->dma_channels.dma_tx_channel = dma_tx_chan; | 890 | dspi->dma.tx_channel = dma_tx_chan; |
904 | davinci_spi->dma_channels.eventq = dma_eventq; | 891 | dspi->dma.eventq = dma_eventq; |
905 | 892 | ||
906 | ret = davinci_spi_request_dma(davinci_spi); | 893 | ret = davinci_spi_request_dma(dspi); |
907 | if (ret) | 894 | if (ret) |
908 | goto free_clk; | 895 | goto free_clk; |
909 | 896 | ||
@@ -913,19 +900,19 @@ static int davinci_spi_probe(struct platform_device *pdev) | |||
913 | dma_eventq); | 900 | dma_eventq); |
914 | } | 901 | } |
915 | 902 | ||
916 | davinci_spi->get_rx = davinci_spi_rx_buf_u8; | 903 | dspi->get_rx = davinci_spi_rx_buf_u8; |
917 | davinci_spi->get_tx = davinci_spi_tx_buf_u8; | 904 | dspi->get_tx = davinci_spi_tx_buf_u8; |
918 | 905 | ||
919 | init_completion(&davinci_spi->done); | 906 | init_completion(&dspi->done); |
920 | 907 | ||
921 | /* Reset In/OUT SPI module */ | 908 | /* Reset In/OUT SPI module */ |
922 | iowrite32(0, davinci_spi->base + SPIGCR0); | 909 | iowrite32(0, dspi->base + SPIGCR0); |
923 | udelay(100); | 910 | udelay(100); |
924 | iowrite32(1, davinci_spi->base + SPIGCR0); | 911 | iowrite32(1, dspi->base + SPIGCR0); |
925 | 912 | ||
926 | /* Set up SPIPC0. CS and ENA init is done in davinci_spi_setup */ | 913 | /* Set up SPIPC0. CS and ENA init is done in davinci_spi_setup */ |
927 | spipc0 = SPIPC0_DIFUN_MASK | SPIPC0_DOFUN_MASK | SPIPC0_CLKFUN_MASK; | 914 | spipc0 = SPIPC0_DIFUN_MASK | SPIPC0_DOFUN_MASK | SPIPC0_CLKFUN_MASK; |
928 | iowrite32(spipc0, davinci_spi->base + SPIPC0); | 915 | iowrite32(spipc0, dspi->base + SPIPC0); |
929 | 916 | ||
930 | /* initialize chip selects */ | 917 | /* initialize chip selects */ |
931 | if (pdata->chip_sel) { | 918 | if (pdata->chip_sel) { |
@@ -936,40 +923,40 @@ static int davinci_spi_probe(struct platform_device *pdev) | |||
936 | } | 923 | } |
937 | 924 | ||
938 | if (pdata->intr_line) | 925 | if (pdata->intr_line) |
939 | iowrite32(SPI_INTLVL_1, davinci_spi->base + SPILVL); | 926 | iowrite32(SPI_INTLVL_1, dspi->base + SPILVL); |
940 | else | 927 | else |
941 | iowrite32(SPI_INTLVL_0, davinci_spi->base + SPILVL); | 928 | iowrite32(SPI_INTLVL_0, dspi->base + SPILVL); |
942 | 929 | ||
943 | iowrite32(CS_DEFAULT, davinci_spi->base + SPIDEF); | 930 | iowrite32(CS_DEFAULT, dspi->base + SPIDEF); |
944 | 931 | ||
945 | /* master mode default */ | 932 | /* master mode default */ |
946 | set_io_bits(davinci_spi->base + SPIGCR1, SPIGCR1_CLKMOD_MASK); | 933 | set_io_bits(dspi->base + SPIGCR1, SPIGCR1_CLKMOD_MASK); |
947 | set_io_bits(davinci_spi->base + SPIGCR1, SPIGCR1_MASTER_MASK); | 934 | set_io_bits(dspi->base + SPIGCR1, SPIGCR1_MASTER_MASK); |
948 | set_io_bits(davinci_spi->base + SPIGCR1, SPIGCR1_POWERDOWN_MASK); | 935 | set_io_bits(dspi->base + SPIGCR1, SPIGCR1_POWERDOWN_MASK); |
949 | 936 | ||
950 | ret = spi_bitbang_start(&davinci_spi->bitbang); | 937 | ret = spi_bitbang_start(&dspi->bitbang); |
951 | if (ret) | 938 | if (ret) |
952 | goto free_dma; | 939 | goto free_dma; |
953 | 940 | ||
954 | dev_info(&pdev->dev, "Controller at 0x%p\n", davinci_spi->base); | 941 | dev_info(&pdev->dev, "Controller at 0x%p\n", dspi->base); |
955 | 942 | ||
956 | return ret; | 943 | return ret; |
957 | 944 | ||
958 | free_dma: | 945 | free_dma: |
959 | edma_free_channel(davinci_spi->dma_channels.dma_tx_channel); | 946 | edma_free_channel(dspi->dma.tx_channel); |
960 | edma_free_channel(davinci_spi->dma_channels.dma_rx_channel); | 947 | edma_free_channel(dspi->dma.rx_channel); |
961 | edma_free_slot(davinci_spi->dma_channels.dummy_param_slot); | 948 | edma_free_slot(dspi->dma.dummy_param_slot); |
962 | free_clk: | 949 | free_clk: |
963 | clk_disable(davinci_spi->clk); | 950 | clk_disable(dspi->clk); |
964 | clk_put(davinci_spi->clk); | 951 | clk_put(dspi->clk); |
965 | put_master: | 952 | put_master: |
966 | spi_master_put(master); | 953 | spi_master_put(master); |
967 | irq_free: | 954 | irq_free: |
968 | free_irq(davinci_spi->irq, davinci_spi); | 955 | free_irq(dspi->irq, dspi); |
969 | unmap_io: | 956 | unmap_io: |
970 | iounmap(davinci_spi->base); | 957 | iounmap(dspi->base); |
971 | release_region: | 958 | release_region: |
972 | release_mem_region(davinci_spi->pbase, resource_size(r)); | 959 | release_mem_region(dspi->pbase, resource_size(r)); |
973 | free_master: | 960 | free_master: |
974 | kfree(master); | 961 | kfree(master); |
975 | err: | 962 | err: |
@@ -987,22 +974,22 @@ err: | |||
987 | */ | 974 | */ |
988 | static int __exit davinci_spi_remove(struct platform_device *pdev) | 975 | static int __exit davinci_spi_remove(struct platform_device *pdev) |
989 | { | 976 | { |
990 | struct davinci_spi *davinci_spi; | 977 | struct davinci_spi *dspi; |
991 | struct spi_master *master; | 978 | struct spi_master *master; |
992 | struct resource *r; | 979 | struct resource *r; |
993 | 980 | ||
994 | master = dev_get_drvdata(&pdev->dev); | 981 | master = dev_get_drvdata(&pdev->dev); |
995 | davinci_spi = spi_master_get_devdata(master); | 982 | dspi = spi_master_get_devdata(master); |
996 | 983 | ||
997 | spi_bitbang_stop(&davinci_spi->bitbang); | 984 | spi_bitbang_stop(&dspi->bitbang); |
998 | 985 | ||
999 | clk_disable(davinci_spi->clk); | 986 | clk_disable(dspi->clk); |
1000 | clk_put(davinci_spi->clk); | 987 | clk_put(dspi->clk); |
1001 | spi_master_put(master); | 988 | spi_master_put(master); |
1002 | free_irq(davinci_spi->irq, davinci_spi); | 989 | free_irq(dspi->irq, dspi); |
1003 | iounmap(davinci_spi->base); | 990 | iounmap(dspi->base); |
1004 | r = platform_get_resource(pdev, IORESOURCE_MEM, 0); | 991 | r = platform_get_resource(pdev, IORESOURCE_MEM, 0); |
1005 | release_mem_region(davinci_spi->pbase, resource_size(r)); | 992 | release_mem_region(dspi->pbase, resource_size(r)); |
1006 | 993 | ||
1007 | return 0; | 994 | return 0; |
1008 | } | 995 | } |