diff options
Diffstat (limited to 'drivers/spi')
-rw-r--r-- | drivers/spi/davinci_spi.c | 53 |
1 files changed, 31 insertions, 22 deletions
diff --git a/drivers/spi/davinci_spi.c b/drivers/spi/davinci_spi.c index d5d7014e6ae2..17269ad54a99 100644 --- a/drivers/spi/davinci_spi.c +++ b/drivers/spi/davinci_spi.c | |||
@@ -53,6 +53,7 @@ | |||
53 | #define SPIFMT_WDELAY_MASK 0x3f000000u | 53 | #define SPIFMT_WDELAY_MASK 0x3f000000u |
54 | #define SPIFMT_WDELAY_SHIFT 24 | 54 | #define SPIFMT_WDELAY_SHIFT 24 |
55 | #define SPIFMT_CHARLEN_MASK 0x0000001Fu | 55 | #define SPIFMT_CHARLEN_MASK 0x0000001Fu |
56 | #define SPIFMT_PRESCALE_SHIFT 8 | ||
56 | 57 | ||
57 | 58 | ||
58 | /* SPIPC0 */ | 59 | /* SPIPC0 */ |
@@ -267,6 +268,29 @@ static void davinci_spi_chipselect(struct spi_device *spi, int value) | |||
267 | } | 268 | } |
268 | 269 | ||
269 | /** | 270 | /** |
271 | * davinci_spi_get_prescale - Calculates the correct prescale value | ||
272 | * @maxspeed_hz: the maximum rate the SPI clock can run at | ||
273 | * | ||
274 | * This function calculates the prescale value that generates a clock rate | ||
275 | * less than or equal to the specified maximum. | ||
276 | * | ||
277 | * Returns: calculated prescale - 1 for easy programming into SPI registers | ||
278 | * or negative error number if valid prescalar cannot be updated. | ||
279 | */ | ||
280 | static inline int davinci_spi_get_prescale(struct davinci_spi *davinci_spi, | ||
281 | u32 max_speed_hz) | ||
282 | { | ||
283 | int ret; | ||
284 | |||
285 | ret = DIV_ROUND_UP(clk_get_rate(davinci_spi->clk), max_speed_hz); | ||
286 | |||
287 | if (ret < 3 || ret > 256) | ||
288 | return -EINVAL; | ||
289 | |||
290 | return ret - 1; | ||
291 | } | ||
292 | |||
293 | /** | ||
270 | * davinci_spi_setup_transfer - This functions will determine transfer method | 294 | * davinci_spi_setup_transfer - This functions will determine transfer method |
271 | * @spi: spi device on which data transfer to be done | 295 | * @spi: spi device on which data transfer to be done |
272 | * @t: spi transfer in which transfer info is filled | 296 | * @t: spi transfer in which transfer info is filled |
@@ -281,7 +305,7 @@ static int davinci_spi_setup_transfer(struct spi_device *spi, | |||
281 | 305 | ||
282 | struct davinci_spi *davinci_spi; | 306 | struct davinci_spi *davinci_spi; |
283 | u8 bits_per_word = 0; | 307 | u8 bits_per_word = 0; |
284 | u32 hz = 0, prescale = 0, clkspeed; | 308 | u32 hz = 0, prescale = 0; |
285 | 309 | ||
286 | davinci_spi = spi_master_get_devdata(spi->master); | 310 | davinci_spi = spi_master_get_devdata(spi->master); |
287 | 311 | ||
@@ -312,21 +336,18 @@ static int davinci_spi_setup_transfer(struct spi_device *spi, | |||
312 | if (!hz) | 336 | if (!hz) |
313 | hz = spi->max_speed_hz; | 337 | hz = spi->max_speed_hz; |
314 | 338 | ||
339 | prescale = davinci_spi_get_prescale(davinci_spi, hz); | ||
340 | if (prescale < 0) | ||
341 | return prescale; | ||
342 | |||
315 | clear_fmt_bits(davinci_spi->base, SPIFMT_CHARLEN_MASK, | 343 | clear_fmt_bits(davinci_spi->base, SPIFMT_CHARLEN_MASK, |
316 | spi->chip_select); | 344 | spi->chip_select); |
317 | set_fmt_bits(davinci_spi->base, bits_per_word & 0x1f, | 345 | set_fmt_bits(davinci_spi->base, bits_per_word & 0x1f, |
318 | spi->chip_select); | 346 | spi->chip_select); |
319 | 347 | ||
320 | clkspeed = clk_get_rate(davinci_spi->clk); | ||
321 | if (hz > clkspeed / 2) | ||
322 | prescale = 1 << 8; | ||
323 | if (hz < clkspeed / 256) | ||
324 | prescale = 255 << 8; | ||
325 | if (!prescale) | ||
326 | prescale = ((clkspeed / hz - 1) << 8) & 0x0000ff00; | ||
327 | |||
328 | clear_fmt_bits(davinci_spi->base, 0x0000ff00, spi->chip_select); | 348 | clear_fmt_bits(davinci_spi->base, 0x0000ff00, spi->chip_select); |
329 | set_fmt_bits(davinci_spi->base, prescale, spi->chip_select); | 349 | set_fmt_bits(davinci_spi->base, |
350 | prescale << SPIFMT_PRESCALE_SHIFT, spi->chip_select); | ||
330 | 351 | ||
331 | return 0; | 352 | return 0; |
332 | } | 353 | } |
@@ -413,10 +434,8 @@ static int davinci_spi_setup(struct spi_device *spi) | |||
413 | int retval; | 434 | int retval; |
414 | struct davinci_spi *davinci_spi; | 435 | struct davinci_spi *davinci_spi; |
415 | struct davinci_spi_dma *davinci_spi_dma; | 436 | struct davinci_spi_dma *davinci_spi_dma; |
416 | struct device *sdev; | ||
417 | 437 | ||
418 | davinci_spi = spi_master_get_devdata(spi->master); | 438 | davinci_spi = spi_master_get_devdata(spi->master); |
419 | sdev = davinci_spi->bitbang.master->dev.parent; | ||
420 | 439 | ||
421 | /* if bits per word length is zero then set it default 8 */ | 440 | /* if bits per word length is zero then set it default 8 */ |
422 | if (!spi->bits_per_word) | 441 | if (!spi->bits_per_word) |
@@ -436,16 +455,6 @@ static int davinci_spi_setup(struct spi_device *spi) | |||
436 | } | 455 | } |
437 | 456 | ||
438 | /* | 457 | /* |
439 | * SPI in DaVinci and DA8xx operate between | ||
440 | * 600 KHz and 50 MHz | ||
441 | */ | ||
442 | if (spi->max_speed_hz < 600000 || spi->max_speed_hz > 50000000) { | ||
443 | dev_dbg(sdev, "Operating frequency is not in acceptable " | ||
444 | "range\n"); | ||
445 | return -EINVAL; | ||
446 | } | ||
447 | |||
448 | /* | ||
449 | * Set up SPIFMTn register, unique to this chipselect. | 458 | * Set up SPIFMTn register, unique to this chipselect. |
450 | * | 459 | * |
451 | * NOTE: we could do all of these with one write. Also, some | 460 | * NOTE: we could do all of these with one write. Also, some |