1. 11 12月, 2014 3 次提交
    • M
      spi: Pump transfers inside calling context for spi_sync() · 0461a414
      Mark Brown 提交于
      If we are using the standard SPI message pump (which all drivers should be
      transitioning over to) then special case the message enqueue and instead of
      starting the worker thread to push messages to the hardware do so in the
      context of the caller if the controller is idle. This avoids a context
      switch in the common case where the controller has a single user in a
      single thread, for short PIO transfers there may be no need to context
      switch away from the calling context to complete the transfer.
      
      The code is a bit more complex than is desirable in part due to the need
      to handle drivers not using the standard queue and in part due to handling
      the various combinations of bus locking and asynchronous submission in
      interrupt context.
      
      It is still suboptimal since it will still wake the message pump for each
      transfer in order to schedule idling of the hardware and if multiple
      contexts are using the controller simultaneously a caller may end up
      pumping a message for some random other thread rather than for itself,
      and if the thread ends up deferring due to another context idling the
      hardware then it will just busy wait.  It can, however, have the benefit
      of aggregating power up and down of the hardware when a caller performs
      a series of transfers back to back without any need for the use of
      spi_async().
      Signed-off-by: NMark Brown <broonie@kernel.org>
      0461a414
    • M
      spi: Check to see if the device is processing a message before we idle · 983aee5d
      Mark Brown 提交于
      cur_msg is updated under the queue lock and holds the message we are
      currently processing. Since currently we only ever do removals in the
      pump kthread it doesn't matter in what order we do things but we want
      to be able to push things out from the submitting thread so pull the
      check to see if we're currently handling a message before we check to
      see if the queue is idle.
      Signed-off-by: NMark Brown <broonie@kernel.org>
      983aee5d
    • M
      spi: Move queue data structure initialisation to main master init · 5424d43e
      Mark Brown 提交于
      Since most devices now do use the standard queue and in order to avoid
      initialisation ordering issues being introduced by further refactorings
      to improve performance move the initialisation of the queue and the lock
      for it to the main master allocation.
      Signed-off-by: NMark Brown <broonie@kernel.org>
      5424d43e
  2. 05 12月, 2014 1 次提交
  3. 17 11月, 2014 1 次提交
    • C
      spi: Fix mapping from vmalloc-ed buffer to scatter list · c1aefbdd
      Charles Keepax 提交于
      We can only use page_address on memory that has been mapped using kmap,
      when the buffer passed to the SPI has been allocated by vmalloc the page
      has not necessarily been mapped through kmap. This means sometimes
      page_address will return NULL causing the pointer we pass to sg_set_buf
      to be invalid.
      
      As we only call page_address so that we can pass a virtual address to
      sg_set_buf which will then immediately call virt_to_page on it, fix this
      by calling sg_set_page directly rather then relying on the sg_set_buf
      helper.
      Signed-off-by: NCharles Keepax <ckeepax@opensource.wolfsonmicro.com>
      Signed-off-by: NMark Brown <broonie@kernel.org>
      Cc: stable@vger.kernel.org
      c1aefbdd
  4. 30 9月, 2014 1 次提交
  5. 24 9月, 2014 1 次提交
  6. 22 9月, 2014 1 次提交
  7. 20 8月, 2014 1 次提交
  8. 13 8月, 2014 1 次提交
  9. 26 7月, 2014 1 次提交
  10. 11 7月, 2014 2 次提交
  11. 21 6月, 2014 2 次提交
  12. 26 5月, 2014 1 次提交
  13. 04 5月, 2014 1 次提交
  14. 03 5月, 2014 1 次提交
  15. 19 4月, 2014 1 次提交
    • G
      spi: core: Ignore unsupported Dual/Quad Transfer Mode bits · 83596fbe
      Geert Uytterhoeven 提交于
      The availability of SPI Dual or Quad Transfer Mode as indicated by the
      "spi-tx-bus-width" and "spi-rx-bus-width" properties in the device tree is
      a hardware property of the SPI master, SPI slave, and board wiring.  Hence
      the SPI core should not reject an SPI slave because an SPI master driver
      doesn't (yet) support Dual or Quad Transfer Mode.
      
      Change the lack of Dual or Quad Transfer Mode support in the SPI master
      driver from an error condition to a warning condition, and ignore the
      unsupported mode bits, falling back to Single Transfer Mode, to avoid
      breakages when running old kernels with new device trees.
      
      Fixes: f477b7fb (spi: DUAL and QUAD support)
      Signed-off-by: NGeert Uytterhoeven <geert+renesas@glider.be>
      Signed-off-by: NMark Brown <broonie@linaro.org>
      Cc: stable@vger.kernel.org
      83596fbe
  16. 15 4月, 2014 2 次提交
    • Z
      spi: add "spi-lsb-first" to devicetree · cd6339e6
      Zhao Qiang 提交于
      add optional property devicetree for SPI slave nodes
      into devicetree so that LSB mode can be enabled by devicetree.
      Signed-off-by: NZhao Qiang <B45475@freescale.com>
      Signed-off-by: NMark Brown <broonie@linaro.org>
      cd6339e6
    • H
      spi: core: Increase timeout value · eee668a9
      Harini Katakam 提交于
      The existing timeout value in wait_for_completion_timeout is
      calculated from the transfer length and speed with tolerance of 10msec.
      This is too low because this is used for error conditions such as
      hardware hang etc.
      The xfer->speed_hz considered may not be the actual speed set
      because the best clock divisor is chosen from a limited set such that
      the actual speed <= requested speed. This will lead to timeout being
      less than actual transfer time.
      Considering acceptable latencies, this timeout can be set to a
      value double the expected transfer plus 100 msecs.
      This patch adds the same in the core.
      Signed-off-by: NHarini Katakam <harinik@xilinx.com>
      Signed-off-by: NMark Brown <broonie@linaro.org>
      eee668a9
  17. 30 3月, 2014 1 次提交
  18. 26 3月, 2014 1 次提交
    • M
      spi: Do not require a completion · 1e25cd47
      Mark Brown 提交于
      There is no real reason why we require transfers to have a completion and
      the only user of the completion now checks to see if one has been provided
      before using it so stop enforcing this. This makes it more convenient for
      drivers to chain multiple asynchronous transfers together.
      Signed-off-by: NMark Brown <broonie@linaro.org>
      1e25cd47
  19. 17 3月, 2014 1 次提交
  20. 04 3月, 2014 1 次提交
  21. 23 2月, 2014 1 次提交
  22. 22 2月, 2014 1 次提交
  23. 14 2月, 2014 1 次提交
  24. 13 2月, 2014 1 次提交
  25. 10 2月, 2014 1 次提交
    • A
      spi: core: Set max_speed_hz of spi_device default to max_speed_hz of controller · 052eb2d4
      Axel Lin 提交于
      In __spi_validate(), xfer->speed_hz is set to be spi->max_speed_hz if it is not
      set for this transfer. However, if spi->max_speed_hz is also not set,
      xfer->speed_hz is 0. Some drivers (e.g. au1550, tegra114, tegra20-sflash,
      tegra20-slink, etc.) then use below code to avoid setting xfer->speed_hz to 0.
      
              /* Set speed to the spi max fequency if spi device has not set */
              spi->max_speed_hz = spi->max_speed_hz ? : tspi->spi_max_frequency;
      
      Let's handle it in spi core.
      If spi->max_speed_hz is not set, make it default to spi->master->max_speed_hz.
      So In __spi_validate() if both xfer->speed_hz and spi->max_speed_hz are not set,
      xfer->speed_hz will be set to spi->master->max_speed_hz.
      Signed-off-by: NAxel Lin <axel.lin@ingics.com>
      Signed-off-by: NMark Brown <broonie@linaro.org>
      052eb2d4
  26. 05 2月, 2014 2 次提交
    • M
      spi: Make core DMA mapping functions generate scatterlists · 6ad45a27
      Mark Brown 提交于
      We cannot unconditionally use dma_map_single() to map data for use with
      SPI since transfers may exceed a page and virtual addresses may not be
      provided with physically contiguous pages. Further, addresses allocated
      using vmalloc() need to be mapped differently to other addresses.
      
      Currently only the MXS driver handles all this, a few drivers do handle
      the possibility that buffers may not be physically contiguous which is
      the main potential problem but many don't even do that. Factoring this
      out into the core will make it easier for drivers to do a good job so if
      the driver is using the core DMA code then generate a scatterlist
      instead of mapping to a single address so do that.
      
      This code is mainly based on a combination of the existing code in the MXS
      and PXA2xx drivers. In future we should be able to extend it to allow the
      core to concatenate adjacent transfers if they are compatible, improving
      performance.
      
      Currently for simplicity clients are not allowed to use the scatterlist
      when they do DMA mapping, in the future the existing single address
      mappings will be replaced with use of the scatterlist most likely as
      part of pre-verifying transfers.
      
      This change makes it mandatory to use scatterlists when using the core DMA
      mapping so update the s3c64xx driver to do this when used with dmaengine.
      Doing so makes the code more ugly but it is expected that the old s3c-dma
      code can be removed very soon.
      Signed-off-by: NMark Brown <broonie@linaro.org>
      6ad45a27
    • M
      spi: Provide core support for full duplex devices · 3a2eba9b
      Mark Brown 提交于
      It is fairly common for SPI devices to require that one or both transfer
      directions is always active. Currently drivers open code this in various
      ways with varying degrees of efficiency. Start factoring this out by
      providing flags SPI_MASTER_MUST_TX and SPI_MASTER_MUST_RX. These will cause
      the core to provide buffers for the requested direction if none are
      specified in the underlying transfer.
      
      Currently this is fairly inefficient since we actually allocate a data
      buffer which may get large, support for mapping transfers using a
      scatterlist will allow us to avoid this for DMA based transfers.
      Signed-off-by: NMark Brown <broonie@linaro.org>
      3a2eba9b
  27. 03 2月, 2014 2 次提交
    • M
      spi: Provide core support for DMA mapping transfers · 99adef31
      Mark Brown 提交于
      The process of DMA mapping buffers for SPI transfers does not vary between
      devices so in order to save duplication of code in drivers this can be
      factored out into the core, allowing it to be integrated with the work that
      is being done on factoring out the common elements from the data path
      including more sharing of dmaengine code.
      
      In order to use this masters need to provide a can_dma() operation and while
      the hardware is prepared they should ensure that DMA channels are provided
      in tx_dma and rx_dma. The core will then ensure that the buffers are mapped
      for DMA prior to calling transfer_one_message().
      
      Currently the cleanup on error is not complete, this needs to be improved.
      Signed-off-by: NMark Brown <broonie@linaro.org>
      99adef31
    • M
      spi: Add a timeout when waiting for transfers · 16a0ce4e
      Mark Brown 提交于
      Don't wait indefinitely for transfers to complete but time out after 10ms
      more than we expect the transfer to take on the wire.
      Signed-off-by: NMark Brown <broonie@linaro.org>
      16a0ce4e
  28. 29 1月, 2014 1 次提交
    • G
      spi: Fix crash with double message finalisation on error handling · 1f802f82
      Geert Uytterhoeven 提交于
      This reverts commit e120cc0d.
      
      It causes a NULL pointer dereference with drivers using the generic
      spi_transfer_one_message(), which always calls
      spi_finalize_current_message(), which zeroes master->cur_msg.
      
      Drivers implementing transfer_one_message() theirselves must always call
      spi_finalize_current_message(), even if the transfer failed:
      
       * @transfer_one_message: the subsystem calls the driver to transfer a single
       *      message while queuing transfers that arrive in the meantime. When the
       *      driver is finished with this message, it must call
       *      spi_finalize_current_message() so the subsystem can issue the next
       *      transfer
      Signed-off-by: NGeert Uytterhoeven <geert+renesas@linux-m68k.org>
      Signed-off-by: NMark Brown <broonie@linaro.org>
      1f802f82
  29. 22 1月, 2014 2 次提交
  30. 17 1月, 2014 1 次提交
    • Z
      ACPI: fix module autoloading for ACPI enumerated devices · 8c4ff6d0
      Zhang Rui 提交于
      ACPI enumerated devices has ACPI style _HID and _CID strings,
      all of these strings can be used for both driver loading and matching.
      
      Currently, in Platform, I2C and SPI bus, the ACPI style driver matching
      is supported by invoking acpi_driver_match_device() in bus .match() callback.
      But, the module autoloading is still broken.
      
      For example, there is any ACPI device with _HID "INTABCD" that is
      enumerated to platform bus, and we have a driver that can probe it.
      
      The driver exports its module_alias as "acpi:INTABCD" use the following code
      static const struct acpi_device_id xxx_acpi_match[] = {
              { "INTABCD", 0 },
              { }
      };
      MODULE_DEVICE_TABLE(acpi, xxx_acpi_match);
      
      But, unfortunately, the device' modalias is shown as "platform:INTABCD:00",
      please refer to modalias_show() and platform_uevent() in
      drivers/base/platform.c.
      This results in that the driver will not be loaded automatically when the
      device node is created, because their modalias do not match.
      
      This also applies to I2C and SPI bus.
      
      With this patch, the device' modalias will be shown as "acpi:INTABCD" as well.
      Signed-off-by: NZhang Rui <rui.zhang@intel.com>
      Acked-by: NMark Brown <broonie@linaro.org>
      Acked-by: NWolfram Sang <wsa@the-dreams.de>
      Signed-off-by: NRafael J. Wysocki <rafael.j.wysocki@intel.com>
      8c4ff6d0
  31. 13 1月, 2014 1 次提交
  32. 09 1月, 2014 1 次提交