Tiva I2C: Minor clean-up to I2C tracing

This commit is contained in:
Gregory Nutt 2014-12-11 08:11:32 -06:00
parent 475d2c3137
commit 3958661ae5

View File

@ -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 */