Skip to content

Commit

Permalink
Calculate I3C timeout based on data size and SCL frequency
Browse files Browse the repository at this point in the history
Default timeout values used during transactions fall short on large data
transfers. Use SCL frequency and data size to calculate a dynamic
timeout value.

Signed-off-by: Tahsin Mutlugun <Tahsin.Mutlugun@analog.com>
  • Loading branch information
ttmut committed Dec 16, 2024
1 parent eeb59b5 commit 6beb170
Showing 1 changed file with 11 additions and 3 deletions.
14 changes: 11 additions & 3 deletions Libraries/PeriphDrivers/Source/I3C/i3c_reva.c
Original file line number Diff line number Diff line change
Expand Up @@ -582,6 +582,8 @@ int MXC_I3C_RevA_Controller_Transaction(mxc_i3c_reva_regs_t *i3c, const mxc_i3c_
int ret;
uint8_t readCount;
uint16_t remaining;
uint32_t timeout;
uint32_t freq;

if (MXC_I3C_RevA_Controller_GetState(i3c) != MXC_V_I3C_REVA_CONT_STATUS_STATE_IDLE &&
MXC_I3C_RevA_Controller_GetState(i3c) != MXC_V_I3C_REVA_CONT_STATUS_STATE_SDR_NORM) {
Expand All @@ -598,10 +600,12 @@ int MXC_I3C_RevA_Controller_Transaction(mxc_i3c_reva_regs_t *i3c, const mxc_i3c_
if (!req->is_i2c) {
ret = MXC_I3C_RevA_EmitStart(i3c, req->is_i2c, MXC_I3C_TRANSFER_TYPE_WRITE,
MXC_I3C_BROADCAST_ADDR, 0);

if (ret < 0) {
goto err;
}
freq = MXC_I3C_RevA_GetPPFrequency(i3c);
} else {
freq = MXC_I3C_RevA_GetI2CFrequency(i3c);
}

/* Restart with write */
Expand All @@ -612,7 +616,9 @@ int MXC_I3C_RevA_Controller_Transaction(mxc_i3c_reva_regs_t *i3c, const mxc_i3c_
goto err;
}

ret = MXC_I3C_RevA_WriteTXFIFO(i3c, req->tx_buf, req->tx_len, true, 100);
timeout = (uint32_t)(40 * 1000000 / freq) * req->tx_len;

ret = MXC_I3C_RevA_WriteTXFIFO(i3c, req->tx_buf, req->tx_len, true, timeout);
if (ret < 0) {
goto err;
}
Expand All @@ -633,8 +639,10 @@ int MXC_I3C_RevA_Controller_Transaction(mxc_i3c_reva_regs_t *i3c, const mxc_i3c_
goto err;
}

timeout = (uint32_t)(80 * 1000000 / freq) * readCount;

ret = MXC_I3C_RevA_ReadRXFIFO(i3c, req->rx_buf + (req->rx_len - remaining), readCount,
1000);
timeout);
if (ret == readCount) {
remaining -= readCount;
} else {
Expand Down

0 comments on commit 6beb170

Please sign in to comment.