1
0
Fork 0
mirror of https://git.rwth-aachen.de/acs/public/villas/node/ synced 2025-03-23 00:00:01 +01:00
VILLASnode/src/path.c
2014-06-05 09:35:16 +00:00

84 lines
1.4 KiB
C

/**
* Message paths
*
* @author Steffen Vogel <stvogel@eonerc.rwth-aachen.de>
* @copyright 2014, Institute for Automation of Complex Power Systems, EONERC
*/
#include <string.h>
#include <stdlib.h>
#include <errno.h>
#include "cfg.h"
#include "utils.h"
#include "path.h"
int path_create(struct path *p, struct node *in, struct node *out)
{
/* Reset counters */
p->received = 0;
p->delayed = 0;
p->duplicated = 0;
p->hook = NULL;
p->in = in;
p->out = out;
return 0;
}
/**
* @brief This is the main thread function per path
*/
static void * path_run(void *arg)
{
struct path *p = (struct path *) arg;
struct msg m;
/* main thread loop */
while (1) {
msg_recv(&m, p->in); /* Receive message */
/* Check message sequence number */
if (m.sequence < p->sequence) {
p->delayed++;
/* Delayed messages will be skipped */
continue;
}
else if (m.sequence == p->sequence) {
p->duplicated++;
}
p->sequence = m.sequence;
p->received++;
/* Call hook */
if (p->hook && p->hook(&m)) {
/* The hook can act as a simple filter
* Returning a non-zero value will skip
* the message from being forwarded */
continue;
}
msg_send(&m, p->out); /* Send message */
}
return NULL;
}
int path_start(struct path *p)
{
pthread_create(&p->tid, NULL, &path_run, (void *) p);
}
int path_stop(struct path *p)
{
void *ret;
pthread_cancel(p->tid);
pthread_join(p->tid, &ret);
return 0;
}