]> granicus.if.org Git - esp-idf/commitdiff
driver: Add notes to SPI driver docs about thread safety
authorAngus Gratton <angus@espressif.com>
Mon, 7 May 2018 01:03:48 +0000 (09:03 +0800)
committerAngus Gratton <gus@projectgus.com>
Mon, 7 May 2018 01:03:48 +0000 (09:03 +0800)
components/driver/include/driver/spi_master.h
docs/en/api-reference/peripherals/spi_master.rst

index ba77b9fb2b959320db039c7a0983ea5a03f6a394..232ad36eb7ed4c1a470b0b01ca85262dc0c2e43a 100644 (file)
@@ -226,15 +226,17 @@ esp_err_t spi_device_get_trans_result(spi_device_handle_t handle, spi_transactio
 
 
 /**
- * @brief Do a SPI transaction
+ * @brief Send a SPI transaction, wait for it to complete, and return the result
  *
- * Essentially does the same as spi_device_queue_trans followed by spi_device_get_trans_result. Do
- * not use this when there is still a transaction queued that hasn't been finalized 
- * using spi_device_get_trans_result.
+ * This function is the equivalent of calling spi_device_queue_trans() followed by spi_device_get_trans_result().
+ * Do not use this when there is still a transaction separately queued from spi_device_queue_trans() that hasn't been finalized
+ * using spi_device_get_trans_result().
+ *
+ * @note This function is not thread safe when multiple tasks access the same SPI device.
  *
  * @param handle Device handle obtained using spi_host_add_dev
  * @param trans_desc Description of transaction to execute
- * @return 
+ * @return
  *         - ESP_ERR_INVALID_ARG   if parameter is invalid
  *         - ESP_OK                on success
  */
index 412c72c947cc4bd927e342374017442bee10ac1c..05474190d74979f0da2bfe2838a7664944a691d5 100644 (file)
@@ -264,6 +264,13 @@ And if the host only writes, the *dummy bit workaround* is not used and the freq
 | 40          | 80                   |
 +-------------+----------------------+
 
+Thread Safety
+-------------
+
+The SPI driver API is thread safe when multiple SPI devices on the same bus are accessed from different tasks. However, the driver is not thread safe if the same SPI device is accessed from multiple tasks.
+
+In this case, it is recommended to either refactor your application so only a single task accesses each SPI device, or to add mutex locking around access of the shared device.
+
 .. _spi_known_issues:
 
 Known Issues