struct {
unsigned enobufs;
unsigned overrun;
+ unsigned lost;
} stats;
int num_interfaces = 0;
return ret;
}
+static inline send_and_check(int s)
+{
+ int ret;
+ ret = send_frame(s);
+ if (ret != sizeof(struct can_frame)) {
+/* if (ret == -1 && errno == ENOBUFS && opt.period_us == 0 && !opt.oneattime) { */
+/* stats.enobufs++; */
+/* /\* Ignore this error - pfifo_fast qeuue is full *\/ */
+/* } else */
+ error(1, errno, "send_frame (line %d)", __LINE__);
+ } else {
+ count++;
+ msg_in_progress++;
+ }
+}
+
static inline void get_next_timeout(struct timespec *timeout)
{
struct timespec now;
set_sched_policy_and_prio(SCHED_FIFO, 40);
-#define SEND() \
- do { \
- ret = send_frame(pfd[0].fd); \
- if (ret != sizeof(struct can_frame)) { \
- if (ret == -1 && errno == ENOBUFS && opt.period_us == 0 && !opt.oneattime) { \
- stats.enobufs++; \
- /* Ignore this error - pfifo_fast qeuue is full */ \
- } else \
- error(1, errno, "send_frame (line %d)", __LINE__); \
- } \
- else { \
- count++; \
- msg_in_progress++; \
- } \
- } while (0)
-
- if (opt.oneattime) {
+#define SEND() send_and_check(pfd[0].fd)
+
+ if (opt.oneattime)
SEND();
- count = 1;
- }
while (!finish_flag &&
(opt.count == 0 || count < opt.count || msg_in_progress != 0)) {
pthread_create(&thread, 0, measure_thread, NULL);
- struct timespec next, now, diff;
+ struct timespec next, now, diff, allsent = {0,0};
clock_gettime(CLOCK_MONOTONIC, &next);
int completed = 0;
while (!finish_flag && (opt.count == 0 || completed < opt.count)) {
next.tv_sec++;
}
}
+ if (opt.count != 0 && count >= opt.count) {
+ if (allsent.tv_sec == 0)
+ allsent = now;
+ if (now.tv_sec - allsent.tv_sec >= 2)
+ finish_flag = 1;
+ }
}
print_progress();
printf("\n");
+ stats.lost = msg_in_progress;
+
pthread_join(thread, NULL);
close(completion_pipe[0]);
printf("overrun=%d\n", stats.overrun);
if (stats.enobufs)
printf("enobufs=%d\n", stats.enobufs);
+ if (stats.lost)
+ printf("lost=%d\n", stats.enobufs);
return 0;
}