1
0
Fork 0
mirror of https://git.rwth-aachen.de/acs/public/villas/node/ synced 2025-03-16 00:00:02 +01:00
VILLASnode/server/src/random.c

68 lines
1.5 KiB
C
Raw Normal View History

/** Generate random packages on stdout.
*
* @author Steffen Vogel <stvogel@eonerc.rwth-aachen.de>
* @copyright 2015, Institute for Automation of Complex Power Systems, EONERC
* @file
* @addtogroup tools Test and debug tools
* @{
*/
#include <stdlib.h>
#include <unistd.h>
#include <time.h>
#include <sys/timerfd.h>
#include "config.h"
#include "utils.h"
#include "msg.h"
#define CLOCKID CLOCK_REALTIME
int main(int argc, char *argv[])
{
if (argc != 3) {
printf("Usage: %s VALUES RATE\n", argv[0]);
printf(" VALUES is the number of values a message contains\n");
printf(" RATE how many messages per second\n\n");
printf("Simulator2Simulator Server %s (built on %s %s)\n",
BLU(VERSION), MAG(__DATE__), MAG(__TIME__));
printf(" Copyright 2015, Institute for Automation of Complex Power Systems, EONERC\n");
printf(" Steffen Vogel <StVogel@eonerc.rwth-aachen.de>\n");
2015-03-21 18:03:55 +01:00
exit(EXIT_FAILURE);
}
int rate = atoi(argv[2]);
struct msg m = MSG_INIT(atoi(argv[1]));
/* Setup timer */
struct itimerspec its = {
.it_interval = timespec_rate(rate),
.it_value = { 1, 0 }
};
int tfd = timerfd_create(CLOCK_REALTIME, 0);
if (tfd < 0)
serror("Failed to create timer");
if (timerfd_settime(tfd, 0, &its, NULL))
serror("Failed to start timer");
/* Print header */
fprintf(stderr, "# %-6s%-12s\n", "seq", "data");
/* Block until 1/p->rate seconds elapsed */
while ((m.sequence = timerfd_wait(tfd))) {
msg_random(&m);
msg_fprint(stdout, &m);
fflush(stdout);
}
close(tfd);
return 0;
}
/** @} */