Tiva I2C: Minor clean-up to I2C tracing
This commit is contained in:
parent
475d2c3137
commit
3958661ae5
@ -175,7 +175,7 @@ struct tiva_trace_s
|
|||||||
{
|
{
|
||||||
uint32_t status; /* I2C 32-bit SR2|SR1 status */
|
uint32_t status; /* I2C 32-bit SR2|SR1 status */
|
||||||
uint32_t count; /* Interrupt count when status change */
|
uint32_t count; /* Interrupt count when status change */
|
||||||
enum tiva_intstate_e event; /* Last event that occurred with this status */
|
enum tiva_trace_e event; /* Last event that occurred with this status */
|
||||||
uint32_t parm; /* Parameter associated with the event */
|
uint32_t parm; /* Parameter associated with the event */
|
||||||
uint32_t time; /* First of event or first status */
|
uint32_t time; /* First of event or first status */
|
||||||
};
|
};
|
||||||
@ -220,7 +220,9 @@ struct tiva_i2c_priv_s
|
|||||||
|
|
||||||
#ifdef CONFIG_I2C_TRACE
|
#ifdef CONFIG_I2C_TRACE
|
||||||
int tndx; /* Trace array index */
|
int tndx; /* Trace array index */
|
||||||
uint32_t start_time; /* Time when the trace was started */
|
int tcount; /* Number of events with this status */
|
||||||
|
uint32_t ttime; /* Time when the trace was started */
|
||||||
|
uint32_t tstatus; /* Last status read */
|
||||||
|
|
||||||
/* The actual trace data */
|
/* The actual trace data */
|
||||||
|
|
||||||
@ -772,7 +774,9 @@ static void tiva_i2c_tracereset(struct tiva_i2c_priv_s *priv)
|
|||||||
/* Reset the trace info for a new data collection */
|
/* Reset the trace info for a new data collection */
|
||||||
|
|
||||||
priv->tndx = 0;
|
priv->tndx = 0;
|
||||||
priv->start_time = clock_systimer();
|
priv->tcount = 0;
|
||||||
|
priv->ttime = clock_systimer();
|
||||||
|
priv->tstatus = 0;
|
||||||
tiva_i2c_traceclear(priv);
|
tiva_i2c_traceclear(priv);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -806,6 +810,11 @@ static void tiva_i2c_tracenew(struct tiva_i2c_priv_s *priv, uint32_t status)
|
|||||||
trace->status = status;
|
trace->status = status;
|
||||||
trace->count = 1;
|
trace->count = 1;
|
||||||
trace->time = clock_systimer();
|
trace->time = clock_systimer();
|
||||||
|
|
||||||
|
/* Save the status and reset the count */
|
||||||
|
|
||||||
|
priv->tstatus = status;
|
||||||
|
priv->tcount = 1;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -823,11 +832,14 @@ static void tiva_i2c_traceevent(struct tiva_i2c_priv_s *priv,
|
|||||||
if (event != I2CEVENT_NONE)
|
if (event != I2CEVENT_NONE)
|
||||||
{
|
{
|
||||||
trace = &priv->trace[priv->tndx];
|
trace = &priv->trace[priv->tndx];
|
||||||
|
if (trace->event != event)
|
||||||
|
{
|
||||||
/* Initialize the new trace entry */
|
/* Initialize the new trace entry */
|
||||||
|
|
||||||
trace->event = event;
|
trace->event = event;
|
||||||
trace->parm = parm;
|
trace->parm = parm;
|
||||||
|
trace->count = priv->tcount;
|
||||||
|
trace->time = clock_systimer();
|
||||||
|
|
||||||
/* Bump up the trace index (unless we are out of trace entries) */
|
/* Bump up the trace index (unless we are out of trace entries) */
|
||||||
|
|
||||||
@ -838,7 +850,18 @@ static void tiva_i2c_traceevent(struct tiva_i2c_priv_s *priv,
|
|||||||
}
|
}
|
||||||
|
|
||||||
priv->tndx++;
|
priv->tndx++;
|
||||||
|
priv->tcount++;
|
||||||
tiva_i2c_traceclear(priv);
|
tiva_i2c_traceclear(priv);
|
||||||
|
|
||||||
|
trace = &priv->trace[priv->tndx];
|
||||||
|
trace->status = priv->status;
|
||||||
|
trace->count = priv->tcount;
|
||||||
|
trace->time = clock_systimer();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
priv->tcount++;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -848,7 +871,7 @@ static void tiva_i2c_tracedump(struct tiva_i2c_priv_s *priv)
|
|||||||
int i;
|
int i;
|
||||||
|
|
||||||
syslog(LOG_DEBUG, "Elapsed time: %d\n",
|
syslog(LOG_DEBUG, "Elapsed time: %d\n",
|
||||||
clock_systimer() - priv->start_time);
|
clock_systimer() - priv->ttime);
|
||||||
|
|
||||||
for (i = 0; i <= priv->tndx; i++)
|
for (i = 0; i <= priv->tndx; i++)
|
||||||
{
|
{
|
||||||
@ -856,7 +879,7 @@ static void tiva_i2c_tracedump(struct tiva_i2c_priv_s *priv)
|
|||||||
syslog(LOG_DEBUG,
|
syslog(LOG_DEBUG,
|
||||||
"%2d. STATUS: %08x COUNT: %3d EVENT: %2d PARM: %08x TIME: %d\n",
|
"%2d. STATUS: %08x COUNT: %3d EVENT: %2d PARM: %08x TIME: %d\n",
|
||||||
i+1, trace->status, trace->count, trace->event, trace->parm,
|
i+1, trace->status, trace->count, trace->event, trace->parm,
|
||||||
trace->time - priv->start_time);
|
trace->time - priv->ttime);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif /* CONFIG_I2C_TRACE */
|
#endif /* CONFIG_I2C_TRACE */
|
||||||
@ -876,10 +899,6 @@ static void tiva_i2c_sendaddress(struct tiva_i2c_priv_s *priv)
|
|||||||
|
|
||||||
DEBUGASSERT(priv && priv->msgc > 0);
|
DEBUGASSERT(priv && priv->msgc > 0);
|
||||||
|
|
||||||
/* Check for new trace setup, post the SENADDRESS event */
|
|
||||||
|
|
||||||
tiva_i2c_tracenew(priv, 0);
|
|
||||||
|
|
||||||
/* Get run-time data for the next message */
|
/* Get run-time data for the next message */
|
||||||
|
|
||||||
msg = priv->msgv;
|
msg = priv->msgv;
|
||||||
@ -1562,6 +1581,7 @@ static int tiva_i2c_process(struct i2c_dev_s *dev, struct i2c_msg_s *msgs,
|
|||||||
/* Reset I2C trace logic */
|
/* Reset I2C trace logic */
|
||||||
|
|
||||||
tiva_i2c_tracereset(priv);
|
tiva_i2c_tracereset(priv);
|
||||||
|
tiva_i2c_tracenew(priv, 0);
|
||||||
|
|
||||||
/* Set I2C clock frequency */
|
/* Set I2C clock frequency */
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user