Skip to content

Commit

Permalink
arch/risc-v/src/mpfs/mpfs_i2c.c: Add more i2cerr traces
Browse files Browse the repository at this point in the history
Add sanity checks for debugging possible errors in the driver.

Signed-off-by: Jukka Laitinen <[email protected]>
  • Loading branch information
jlaitine committed Jan 11, 2024
1 parent 21a0ad6 commit 4896164
Showing 1 changed file with 32 additions and 0 deletions.
32 changes: 32 additions & 0 deletions arch/risc-v/src/mpfs/mpfs_i2c.c
Original file line number Diff line number Diff line change
Expand Up @@ -720,6 +720,10 @@ static int mpfs_i2c_transfer(struct i2c_master_s *dev,
{
struct mpfs_i2c_priv_s *priv = (struct mpfs_i2c_priv_s *)dev;
int ret = OK;
#ifdef CONFIG_DEBUG_I2C_ERROR
int sval;
uint32_t status;
#endif

i2cinfo("Starting transfer request of %d message(s):\n", count);

Expand All @@ -734,6 +738,24 @@ static int mpfs_i2c_transfer(struct i2c_master_s *dev,
return ret;
}

#ifdef CONFIG_DEBUG_I2C_ERROR
/* We should never start at transfer with semaphore already signalled */

sem_getvalue(&priv->sem_isr, &sval);
if (sval != 0)
{
i2cerr("Already signalled at start? %d\n", sval);
}

/* We should always be idle before transfer */

status = getreg32(MPFS_I2C_STATUS);
if (status != MPFS_I2C_ST_IDLE)
{
i2cerr("I2C bus not idle before transfer! Status: 0x%x\n", status);
}
#endif

priv->msgv = msgs;
priv->msgc = count;

Expand Down Expand Up @@ -826,6 +848,16 @@ static int mpfs_i2c_transfer(struct i2c_master_s *dev,
i2cinfo("Message %" PRIu8 " transfer complete.\n", priv->msgid);
}

#ifdef CONFIG_DEBUG_I2C_ERROR
/* We should always be idle after the transfers */

status = getreg32(MPFS_I2C_STATUS);
if (status != MPFS_I2C_ST_IDLE)
{
i2cerr("I2C bus not idle after transfer! Status: 0x%x\n", status);
}
#endif

/* Irq was enabled at mpfs_i2c_sendstart() */

up_disable_irq(priv->plic_irq);
Expand Down

0 comments on commit 4896164

Please sign in to comment.