mbox series

[v4,0/2] Add Block event interrupt support for I2C protocol

Message ID 20241217170424.14703-1-quic_jseerapu@quicinc.com
Headers show
Series Add Block event interrupt support for I2C protocol | expand

Message

Jyothi Kumar Seerapu Dec. 17, 2024, 5:04 p.m. UTC
The I2C driver gets an interrupt upon transfer completion.
When handling multiple messages in a single transfer, this
results in N interrupts for N messages, leading to significant
software interrupt latency.

To mitigate this latency, utilize Block Event Interrupt (BEI)
mechanism. Enabling BEI instructs the hardware to prevent interrupt
generation and BEI is disabled when an interrupt is necessary.

Large I2C transfer can be divided into chunks of 8 messages internally.
Interrupts are not expected for the first 7 message completions, only
the last message triggers an interrupt, indicating the completion of
8 messages. This BEI mechanism enhances overall transfer efficiency.

This optimization reduces transfer time from 168 ms to 48 ms for a
series of 200 I2C write messages in a single transfer, with a
clock frequency support of 100 kHz.

BEI optimizations are currently implemented for I2C write transfers only,
as there is no use case for multiple I2C read messages in a single transfer
at this time.

v3 -> v4:
  - API's added for Block event interrupt with multi descriptor support is 
    moved from qcom-gpi-dma.h file to I2C geni qcom driver file.
  - gpi_multi_xfer_timeout_handler function is moved from GPI driver to
    I2C driver.
  - geni_i2c_gpi_multi_desc_xfer structure is added as a member of
    struct geni_i2c_dev.
  - Removed the changes of making I2C driver is dependent on GPI driver.

v2 -> v3:
  - Updated commit description
  - In I2C GENI driver, for i2c_gpi_cb_result moved the logic of
    "!is_tx_multi_xfer" to else part.
  - MIN_NUM_OF_MSGS_MULTI_DESC changed from 4 to 2
  - Changes of I2C GENI driver to depend on the GPI driver moved
    to patch3.
  - Renamed gpi_multi_desc_process to gpi_multi_xfer_timeout_handler
  - Added description for newly added changes in "qcom-gpi-dma.h" file.

v1 -> v2:
  - DT changes are reverted for adding dma channel size as a new arg of
    dma-cells property.
  - DT binding change reveted for dma channel size as a new arg of
    dma-cells property.
  - In GPI driver, reverted the changes to parse the channel TRE size
    from device tree.
  - Made the changes in QCOM I2C geni driver to support the BEI
    functionality with the existing TRE size of 64.
  - Made changes in QCOM I2C geni driver as per the review comments.
  - Fixed Kernel test robot reported compiltion issues.


Jyothi Kumar Seerapu (2):
  dmaengine: qcom: gpi: Add GPI Block event interrupt support
  i2c: i2c-qcom-geni: Add Block event interrupt support

 drivers/dma/qcom/gpi.c             |   3 +
 drivers/i2c/busses/i2c-qcom-geni.c | 275 ++++++++++++++++++++++++++---
 include/linux/dma/qcom-gpi-dma.h   |   9 +
 3 files changed, 262 insertions(+), 25 deletions(-)

Comments

Andi Shyti Jan. 4, 2025, 12:09 a.m. UTC | #1
Hi,

this patch has been hanging here for a while, can we please have
someone from DMA and Qualcomm look at it?

Thanks,
Andi

On Tue, Dec 17, 2024 at 10:34:22PM +0530, Jyothi Kumar Seerapu wrote:
> The I2C driver gets an interrupt upon transfer completion.
> When handling multiple messages in a single transfer, this
> results in N interrupts for N messages, leading to significant
> software interrupt latency.
> 
> To mitigate this latency, utilize Block Event Interrupt (BEI)
> mechanism. Enabling BEI instructs the hardware to prevent interrupt
> generation and BEI is disabled when an interrupt is necessary.
> 
> Large I2C transfer can be divided into chunks of 8 messages internally.
> Interrupts are not expected for the first 7 message completions, only
> the last message triggers an interrupt, indicating the completion of
> 8 messages. This BEI mechanism enhances overall transfer efficiency.
> 
> This optimization reduces transfer time from 168 ms to 48 ms for a
> series of 200 I2C write messages in a single transfer, with a
> clock frequency support of 100 kHz.
> 
> BEI optimizations are currently implemented for I2C write transfers only,
> as there is no use case for multiple I2C read messages in a single transfer
> at this time.
> 
> v3 -> v4:
>   - API's added for Block event interrupt with multi descriptor support is 
>     moved from qcom-gpi-dma.h file to I2C geni qcom driver file.
>   - gpi_multi_xfer_timeout_handler function is moved from GPI driver to
>     I2C driver.
>   - geni_i2c_gpi_multi_desc_xfer structure is added as a member of
>     struct geni_i2c_dev.
>   - Removed the changes of making I2C driver is dependent on GPI driver.
> 
> v2 -> v3:
>   - Updated commit description
>   - In I2C GENI driver, for i2c_gpi_cb_result moved the logic of
>     "!is_tx_multi_xfer" to else part.
>   - MIN_NUM_OF_MSGS_MULTI_DESC changed from 4 to 2
>   - Changes of I2C GENI driver to depend on the GPI driver moved
>     to patch3.
>   - Renamed gpi_multi_desc_process to gpi_multi_xfer_timeout_handler
>   - Added description for newly added changes in "qcom-gpi-dma.h" file.
> 
> v1 -> v2:
>   - DT changes are reverted for adding dma channel size as a new arg of
>     dma-cells property.
>   - DT binding change reveted for dma channel size as a new arg of
>     dma-cells property.
>   - In GPI driver, reverted the changes to parse the channel TRE size
>     from device tree.
>   - Made the changes in QCOM I2C geni driver to support the BEI
>     functionality with the existing TRE size of 64.
>   - Made changes in QCOM I2C geni driver as per the review comments.
>   - Fixed Kernel test robot reported compiltion issues.
> 
> 
> Jyothi Kumar Seerapu (2):
>   dmaengine: qcom: gpi: Add GPI Block event interrupt support
>   i2c: i2c-qcom-geni: Add Block event interrupt support
> 
>  drivers/dma/qcom/gpi.c             |   3 +
>  drivers/i2c/busses/i2c-qcom-geni.c | 275 ++++++++++++++++++++++++++---
>  include/linux/dma/qcom-gpi-dma.h   |   9 +
>  3 files changed, 262 insertions(+), 25 deletions(-)
> 
> -- 
> 2.17.1
>