1. 17 3月, 2016 2 次提交
  2. 26 2月, 2016 8 次提交
  3. 24 2月, 2016 1 次提交
    • S
      spi: imx: drop fallback to PIO · 99f1cf1c
      Sascha Hauer 提交于
      At the moment the driver decides to fallback to PIO mode the buffers
      are already mapped for DMA. It's a bug to access them with the CPU
      afterwards, so we cannot just fallback to PIO mode.
      It should not be necessary anyway, since we only use DMA when we
      verified that it's possible in the fist place, so when prep_slave_sg
      fails it's a bug, either in the SDMA driver or in the can_dma
      implementation.
      Signed-off-by: NSascha Hauer <s.hauer@pengutronix.de>
      Signed-off-by: NMark Brown <broonie@kernel.org>
      99f1cf1c
  4. 19 2月, 2016 2 次提交
  5. 17 2月, 2016 2 次提交
    • S
      spi: imx: use proper dev_* functions for driver messages · 6aa800ca
      Sascha Hauer 提交于
      Add a struct device * member to the private driver data and use
      it to print messages using dev_* functions rather than pr_*.
      Signed-off-by: NSascha Hauer <s.hauer@pengutronix.de>
      Signed-off-by: NMark Brown <broonie@kernel.org>
      6aa800ca
    • A
      spi: imx: allow only WML aligned transfers to use DMA · 390f0ffe
      Anton Bondarenko 提交于
      RX DMA tail data handling doesn't work correctly in many cases with current
      implementation. It happens because SPI core was setup to generates both RX
      and RX TAIL events. And RX TAIL event does not work correctly.
      This can be easily verified by sending SPI transaction with size modulus
      WML(32 in our case) not equal 0.
      
      Also removing change introduced in f6ee9b58
      since this change only fix usecases with transfer size from 33 to 128 bytes
      and doesn't fix 129 bytes and bigger.
      
      This is output from transaction with len 138 bytes in loopback mode at 10Mhz:
      TX0000: a3 97 a2 55 53 be f1 fc f9 79 6b 52 14 13 e9 e2
      TX0010: 2d 51 8e 1f 56 08 57 27 a7 05 d4 d0 52 82 77 75
      TX0020: 1b 99 4a ed 58 3d 6a 52 36 d5 24 4a 68 8e ad 95
      TX0030: 5f 3c 35 b5 c4 8c dd 6c 11 32 3d e2 b4 b4 59 cf
      TX0040: ce 23 3d 27 df a7 f9 96 fc 1e e0 66 2c 0e 7b 8c
      TX0050: ca 30 42 8f bc 9f 7b ce d1 b8 b1 87 ec 8a d6 bb
      TX0060: 2e 15 63 0e 3c dc a4 3a 7a 06 20 a7 93 1b 34 dd
      TX0070: 4c f5 ec 88 96 68 d6 68 a0 09 6f 8e 93 47 c9 41
      TX0080: db ac cf 97 89 f3 51 05 79 71
      
      RX0000: a3 97 a2 55 53 be f1 fc f9 79 6b 52 14 13 e9 e2
      RX0010: 2d 51 8e 1f 56 08 57 27 a7 05 d4 d0 52 82 77 75
      RX0020: 1b 99 4a ed 58 3d 6a 52 36 d5 24 4a 68 8e ad 95
      RX0030: 5f 3c 35 00 00 b5 00 00 00 c4 00 00 8c 00 00 dd
      RX0040: 6c 11 32 3d e2 b4 b4 59 cf ce 23 3d 27 df a7 f9
      RX0050: 96 fc 1e e0 66 2c 0e 7b 8c ca 30 42 8f 1f 1f bc
      RX0060: 9f 7b ce d1 b8 b1 87 ec 8a d6 bb 2e 15 63 0e ed
      RX0070: ed 3c 58 58 58 dc 3d 3d a4 6a 6a 3a 52 52 7a 36
      RX0080: 06 20 a7 93 1b 34 dd 4c f5 ec
      
      Zeros at offset 33 and 34 caused by reading empty RX FIFO which not possible
      if DMA RX read was triggered by RX event. This mean DMA was triggered
      by RX TAIL event.
      Signed-off-by: NAnton Bondarenko <anton.bondarenko.sama@gmail.com>
      Signed-off-by: NSascha Hauer <s.hauer@pengutronix.de>
      Signed-off-by: NMark Brown <broonie@kernel.org>
      390f0ffe
  6. 23 1月, 2016 1 次提交
  7. 16 12月, 2015 4 次提交
  8. 08 12月, 2015 4 次提交
  9. 04 12月, 2015 1 次提交
  10. 23 10月, 2015 1 次提交
    • A
      spi: imx: fix ecspi mode setup · 1476253c
      Andrew Y. Kuksov 提交于
      Fixed problem with setting spi mode 0 or 1 after setting mode 2 or 3
      
      SPI_MODE_0 and SPI_MODE_1 requires clock low when inactive. SPI_MODE_2
      and SPI_MODE_3 requires clk high when inactive.
      Currently driver can just set bits in fields SCLK_PHA (SPI Clock/Data
      Phase Control), SCLK_POL (SPI Clock Polarity Control),
      SCLK_CTL (controls the inactive state of SCLK) ans SS_POL (SPI SS
      Polarity Select) of ECSPIx_CONFIGREG register.
      This patch allows driver to clear corresponding bits in these fields.
      Signed-off-by: NAndrew Y. Kuksov <qxovxp@gmail.com>
      Signed-off-by: NMark Brown <broonie@kernel.org>
      1476253c
  11. 24 7月, 2015 1 次提交
    • S
      spi: imx: Fix small DMA transfers · f6ee9b58
      Sascha Hauer 提交于
      DMA transfers must be greater than the watermark level size. spi_imx->rx_wml
      and spi_imx->tx_wml contain the watermark level in 32bit words whereas struct
      spi_transfer contains the transfer len in bytes. Fix the check if DMA is
      possible for a transfer accordingly. This fixes transfers with sizes between
      33 and 128 bytes for which previously was claimed that DMA is possible.
      
      Fixes: f62caccd (spi: spi-imx: add DMA support)
      Signed-off-by: NSascha Hauer <s.hauer@pengutronix.de>
      Cc: stable@vger.kernel.org
      Signed-off-by: NMark Brown <broonie@kernel.org>
      f6ee9b58
  12. 02 5月, 2015 1 次提交
  13. 02 4月, 2015 1 次提交
    • L
      spi: imx: read back the RX/TX watermark levels earlier · f511ab09
      Lucas Stach 提交于
      They are used to decide if the controller can do DMA on a buffer
      of a specific length and thus are needed before any transfer is attempted.
      
      This fixes a memory leak where the SPI core uses the drivers can_dma()
      callback to determine if a buffer needs to be mapped. As the watermark
      levels aren't correct at that point the driver falsely claims to be able to
      DMA the buffer when it fact it isn't.
      After the transfer has been done the core uses the same callback to
      determine if it needs to unmap the buffers. As the driver now correctly
      claims to not being able to DMA the buffer the core doesn't attempt to
      unmap the buffer which leaves the SGT leaking.
      
      Fixes: f62caccd (spi: spi-imx: add DMA support)
      Signed-off-by: NLucas Stach <l.stach@pengutronix.de>
      Signed-off-by: NMark Brown <broonie@kernel.org>
      Cc: stable@vger.kernel.org
      f511ab09
  14. 03 3月, 2015 1 次提交
  15. 05 2月, 2015 1 次提交
  16. 03 2月, 2015 1 次提交
  17. 30 12月, 2014 1 次提交
  18. 20 10月, 2014 1 次提交
  19. 18 9月, 2014 1 次提交
  20. 28 2月, 2014 1 次提交
    • P
      spi: spi-imx: spi_imx_remove: do not disable disabled clocks · fd40dccb
      Philippe De Muyter 提交于
      Currently, at module removal, one gets the following warnings:
      ------------[ cut here ]------------
      WARNING: at drivers/clk/clk.c:780 clk_disable+0x18/0x24()
      Modules linked in: spi_imx(-) [last unloaded: ev76c560]
      CPU: 1 PID: 16337 Comm: rmmod Tainted: G        W    3.10.17-80548-g90191eb-dirty #33
      [<80013b4c>] (unwind_backtrace+0x0/0xf8) from [<800115dc>] (show_stack+0x10/0x14)
      [<800115dc>] (show_stack+0x10/0x14) from [<800257b8>] (warn_slowpath_common+0x4c/0x68)
      [<800257b8>] (warn_slowpath_common+0x4c/0x68) from [<800257f0>] (warn_slowpath_null+0x1c/0x24)
      [<800257f0>] (warn_slowpath_null+0x1c/0x24) from [<803f60ec>] (clk_disable+0x18/0x24)
      [<803f60ec>] (clk_disable+0x18/0x24) from [<7f02c9cc>] (spi_imx_remove+0x54/0x9c [spi_imx])
      [<7f02c9cc>] (spi_imx_remove+0x54/0x9c [spi_imx]) from [<8025868c>] (platform_drv_remove+0x18/0x1c)
      [<8025868c>] (platform_drv_remove+0x18/0x1c) from [<80256f60>] (__device_release_driver+0x70/0xcc)
      [<80256f60>] (__device_release_driver+0x70/0xcc) from [<80257770>] (driver_detach+0xcc/0xd0)
      [<80257770>] (driver_detach+0xcc/0xd0) from [<80256d90>] (bus_remove_driver+0x7c/0xc0)
      [<80256d90>] (bus_remove_driver+0x7c/0xc0) from [<80068668>] (SyS_delete_module+0x144/0x1f8)
      [<80068668>] (SyS_delete_module+0x144/0x1f8) from [<8000e080>] (ret_fast_syscall+0x0/0x30)
      ---[ end trace 1f5df9ad54996300 ]---
      ------------[ cut here ]------------
      WARNING: at drivers/clk/clk.c:780 clk_disable+0x18/0x24()
      Modules linked in: spi_imx(-) [last unloaded: ev76c560]
      CPU: 1 PID: 16337 Comm: rmmod Tainted: G        W    3.10.17-80548-g90191eb-dirty #33
      [<80013b4c>] (unwind_backtrace+0x0/0xf8) from [<800115dc>] (show_stack+0x10/0x14)
      [<800115dc>] (show_stack+0x10/0x14) from [<800257b8>] (warn_slowpath_common+0x4c/0x68)
      [<800257b8>] (warn_slowpath_common+0x4c/0x68) from [<800257f0>] (warn_slowpath_null+0x1c/0x24)
      [<800257f0>] (warn_slowpath_null+0x1c/0x24) from [<803f60ec>] (clk_disable+0x18/0x24)
      [<803f60ec>] (clk_disable+0x18/0x24) from [<7f02c9e8>] (spi_imx_remove+0x70/0x9c [spi_imx])
      [<7f02c9e8>] (spi_imx_remove+0x70/0x9c [spi_imx]) from [<8025868c>] (platform_drv_remove+0x18/0x1c)
      [<8025868c>] (platform_drv_remove+0x18/0x1c) from [<80256f60>] (__device_release_driver+0x70/0xcc)
      [<80256f60>] (__device_release_driver+0x70/0xcc) from [<80257770>] (driver_detach+0xcc/0xd0)
      [<80257770>] (driver_detach+0xcc/0xd0) from [<80256d90>] (bus_remove_driver+0x7c/0xc0)
      [<80256d90>] (bus_remove_driver+0x7c/0xc0) from [<80068668>] (SyS_delete_module+0x144/0x1f8)
      [<80068668>] (SyS_delete_module+0x144/0x1f8) from [<8000e080>] (ret_fast_syscall+0x0/0x30)
      ---[ end trace 1f5df9ad54996301 ]---
      
      Since commit 9e556dcc, "spi: spi-imx: only
      enable the clocks when we start to transfer a message", clocks are always
      disabled except when transmitting messages.  There is thus no need to
      disable them at module removal.
      
      Fixes: 9e556dcc (spi: spi-imx: only enable the clocks when we start to transfer a message)
      Signed-off-by: NPhilippe De Muyter <phdm@macqel.be>
      Acked-by: NHuang Shijie <b32955@freescale.com>
      Signed-off-by: NMark Brown <broonie@linaro.org>
      Cc: stable@vger.kernel.org
      fd40dccb
  21. 23 2月, 2014 1 次提交
  22. 15 2月, 2014 1 次提交
  23. 10 2月, 2014 1 次提交
  24. 03 2月, 2014 1 次提交