#ifdef HAVE_CONFIG_H
# include <config.h>
#endif
#include "ntp_types.h"
#include <stdio.h>
#include <stdlib.h>
#define NBUF 100001
#define NSRT 20000
#define NCNT (600 * 1000000)
int col (long *, long *);
int
main(
int argc,
char *argv[]
)
{
struct timeval ts, tr, tp;
struct timezone tzp;
int i, j, n;
long t, u, v, w, gtod[NBUF], ovfl[NSRT];
for (i = 0; i < NBUF; i++)
gtod[i] = 0;
for (i = 0; i < NSRT; i++)
ovfl[i] = 0;
n = 0;
gettimeofday(&ts, &tzp);
t = ts.tv_sec * 1000000 + ts.tv_usec;
v = t;
while (1) {
gettimeofday(&tr, &tzp);
u = tr.tv_sec * 1000000 + tr.tv_usec;
if (u - v > NCNT)
break;
w = u - t;
if (w <= 0) {
} else if (w > NBUF - 1) {
ovfl[n] = w;
if (n < NSRT - 1)
n++;
} else {
gtod[w]++;
}
ts = tr;
t = u;
}
for (i = 0; i < NBUF - 1; i++) {
if (gtod[i] > 0)
printf("%ld %ld\n", i, gtod[i]);
}
if (n == 0)
return;
qsort(
#ifdef QSORT_USES_VOID_P
(void *)
#else
(char *)
#endif
ovfl, (size_t)n, sizeof(long), col);
w = 0;
j = 0;
for (i = 0; i < n; i++) {
if (ovfl[i] != w) {
if (j > 0)
printf("%ld %ld\n", w, j);
w = ovfl[i];
j = 1;
} else
j++;
}
if (j > 0)
printf("%ld %ld\n", w, j);
exit(0);
}
int
col(
long *x,
long *y
)
{
return (*x - *y);
}