Skip to content

Commit

Permalink
feat:[drivers][spi] rt_spi_bus_configure 添加 -RT_EBUSY 返回值,并增加说明注释
Browse files Browse the repository at this point in the history
  • Loading branch information
wdfk-prog authored and mysterywolf committed Oct 6, 2024
1 parent 9bcb904 commit 99503d3
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 2 deletions.
23 changes: 21 additions & 2 deletions components/drivers/include/drivers/dev_spi.h
Original file line number Diff line number Diff line change
Expand Up @@ -184,7 +184,19 @@ rt_err_t rt_spi_bus_attach_device_cspin(struct rt_spi_device *device,
rt_base_t cs_pin,
void *user_data);

/* re-configure SPI bus */
/**
* @brief Reconfigure the SPI bus for the specified device.
* @param device: Pointer to the SPI device attached to the SPI bus.
* @retval RT_EOK if the SPI device was successfully released and the bus was configured.
* RT_EBUSY if the SPI bus is currently in use; the new configuration will take effect once the device releases the bus.
* Other return values indicate failure to configure the SPI bus due to various reasons.
* @note If the configuration of the SPI device has been updated and requires bus re-initialization,
* call this function directly. This function will reconfigure the SPI bus for the specified device.
* If this is the first time to initialize the SPI device, please call rt_spi_configure or rt_qspi_configure.
* This function is used to reconfigure the SPI bus when the SPI device is already in use.
* For further details, refer to:
* https://github.com/RT-Thread/rt-thread/pull/8528
*/
rt_err_t rt_spi_bus_configure(struct rt_spi_device *device);

/**
Expand Down Expand Up @@ -223,7 +235,14 @@ rt_err_t rt_spi_take(struct rt_spi_device *device);
*/
rt_err_t rt_spi_release(struct rt_spi_device *device);

/* set configuration on SPI device */
/**
* @brief This function can set configuration on SPI device.
* @param device: the SPI device attached to SPI bus
* @param cfg: the configuration pointer.
* @retval RT_EOK on release SPI device successfully.
* RT_EBUSY is not an error condition and the configuration will take effect once the device has the bus
* others on taken SPI bus failed.
*/
rt_err_t rt_spi_configure(struct rt_spi_device *device,
struct rt_spi_configuration *cfg);

Expand Down
7 changes: 7 additions & 0 deletions components/drivers/spi/dev_spi_core.c
Original file line number Diff line number Diff line change
Expand Up @@ -106,6 +106,13 @@ rt_err_t rt_spi_bus_configure(struct rt_spi_device *device)
LOG_E("SPI device %s configuration failed", device->parent.parent.name);
}
}
else
{
/* RT_EBUSY is not an error condition and
* the configuration will take effect once the device has the bus
*/
return -RT_EBUSY;
}

/* release lock */
rt_mutex_release(&(device->bus->lock));
Expand Down

0 comments on commit 99503d3

Please sign in to comment.