void msg_info_print(FILE *f, struct msg_info *mi)
{
- struct timespec diff;
+ struct timespec diff, routing_delay, tx_time;
void *local = talloc_new (NULL);
static long num = 0;
char sent[64], received[64];
mi->tx_time_us);
break;
case 3:
- fprintf(f, "%ld: %s %s -> %s (%s) -> %s (%s) %s = %s (%s), %s (%s) %d\n",
+ tx_time.tv_sec = 0;
+ tx_time.tv_nsec = mi->tx_time_us*1000;
+ timespec_subtract(&routing_delay, &mi->ts_rx_final_kern, &mi->ts_rx_onwire_kern);
+ timespec_subtract(&routing_delay, &routing_delay, &tx_time);
+
+ fprintf(f, "%ld: %s %s -> %s (%s) -> %s (%s) %s = %s (%s), %s (%s) %d %s\n",
num, S(mi->ts_sent), sent,
S(mi->ts_rx_onwire_kern), S(mi->ts_rx_onwire),
S(mi->ts_rx_final_kern), S(mi->ts_rx_final), received,
DIFF(mi->ts_sent, mi->ts_rx_onwire),
DIFF(mi->ts_rx_onwire_kern, mi->ts_rx_final_kern),
DIFF(mi->ts_rx_onwire, mi->ts_rx_final),
- mi->tx_time_us);
+ mi->tx_time_us,
+ S(routing_delay));
break;
}
#undef S