2019-01-18 14:10:19 +01:00
|
|
|
#include "dds/dds.h"
|
2018-04-10 17:03:59 +02:00
|
|
|
#include "RoundTrip.h"
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <signal.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
static dds_entity_t waitSet;
|
|
|
|
#define MAX_SAMPLES 10
|
|
|
|
|
|
|
|
/* Forward declarations */
|
2018-08-03 10:33:40 +02:00
|
|
|
static dds_entity_t prepare_dds(dds_entity_t *writer, dds_entity_t *reader, dds_entity_t *readCond, dds_listener_t *listener);
|
2018-08-05 13:24:26 +02:00
|
|
|
static void finalize_dds(dds_entity_t participant, RoundTripModule_DataType data[MAX_SAMPLES]);
|
2018-04-10 17:03:59 +02:00
|
|
|
|
|
|
|
#ifdef _WIN32
|
|
|
|
#include <Windows.h>
|
|
|
|
static bool CtrlHandler (DWORD fdwCtrlType)
|
|
|
|
{
|
|
|
|
dds_waitset_set_trigger (waitSet, true);
|
|
|
|
return true; //Don't let other handlers handle this key
|
|
|
|
}
|
|
|
|
#else
|
2018-08-07 17:30:17 +02:00
|
|
|
static void CtrlHandler (int sig)
|
2018-04-10 17:03:59 +02:00
|
|
|
{
|
2018-08-07 17:30:17 +02:00
|
|
|
(void)sig;
|
2018-04-10 17:03:59 +02:00
|
|
|
dds_waitset_set_trigger (waitSet, true);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2018-08-03 10:33:40 +02:00
|
|
|
static RoundTripModule_DataType data[MAX_SAMPLES];
|
|
|
|
static void * samples[MAX_SAMPLES];
|
|
|
|
static dds_sample_info_t info[MAX_SAMPLES];
|
|
|
|
|
|
|
|
static dds_entity_t participant;
|
|
|
|
static dds_entity_t reader;
|
|
|
|
static dds_entity_t writer;
|
|
|
|
static dds_entity_t readCond;
|
|
|
|
|
2019-01-02 12:09:15 +01:00
|
|
|
static void data_available(dds_entity_t rd, void *arg)
|
2018-08-03 10:33:40 +02:00
|
|
|
{
|
|
|
|
int status, samplecount;
|
|
|
|
(void)arg;
|
2019-01-02 12:09:15 +01:00
|
|
|
samplecount = dds_take (rd, samples, info, MAX_SAMPLES, MAX_SAMPLES);
|
2019-01-18 14:10:19 +01:00
|
|
|
if (samplecount < 0)
|
|
|
|
DDS_FATAL("dds_take: %s\n", dds_strretcode(-samplecount));
|
2018-08-03 10:33:40 +02:00
|
|
|
for (int j = 0; !dds_triggered (waitSet) && j < samplecount; j++)
|
|
|
|
{
|
|
|
|
/* If writer has been disposed terminate pong */
|
|
|
|
|
|
|
|
if (info[j].instance_state == DDS_IST_NOT_ALIVE_DISPOSED)
|
|
|
|
{
|
|
|
|
printf ("Received termination request. Terminating.\n");
|
|
|
|
dds_waitset_set_trigger (waitSet, true);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
else if (info[j].valid_data)
|
|
|
|
{
|
|
|
|
/* If sample is valid, send it back to ping */
|
|
|
|
RoundTripModule_DataType * valid_sample = &data[j];
|
|
|
|
status = dds_write_ts (writer, valid_sample, info[j].source_timestamp);
|
2019-01-18 14:10:19 +01:00
|
|
|
if (status < 0)
|
2019-04-11 15:12:17 +02:00
|
|
|
DDS_FATAL("dds_write_ts: %d\n", -status);
|
2018-08-03 10:33:40 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-04-10 17:03:59 +02:00
|
|
|
int main (int argc, char *argv[])
|
|
|
|
{
|
|
|
|
dds_duration_t waitTimeout = DDS_INFINITY;
|
|
|
|
unsigned int i;
|
2018-08-03 10:33:40 +02:00
|
|
|
int status;
|
2018-04-10 17:03:59 +02:00
|
|
|
dds_attach_t wsresults[1];
|
|
|
|
size_t wsresultsize = 1U;
|
|
|
|
|
2018-08-03 10:33:40 +02:00
|
|
|
dds_listener_t *listener = NULL;
|
|
|
|
bool use_listener = false;
|
|
|
|
int argidx = 1;
|
|
|
|
|
|
|
|
if (argc > argidx && strcmp(argv[argidx], "-l") == 0)
|
|
|
|
{
|
|
|
|
argidx++;
|
|
|
|
use_listener = true;
|
|
|
|
}
|
2018-04-10 17:03:59 +02:00
|
|
|
|
|
|
|
/* Register handler for Ctrl-C */
|
|
|
|
|
|
|
|
#ifdef _WIN32
|
|
|
|
SetConsoleCtrlHandler ((PHANDLER_ROUTINE)CtrlHandler, TRUE);
|
|
|
|
#else
|
|
|
|
struct sigaction sat, oldAction;
|
|
|
|
sat.sa_handler = CtrlHandler;
|
|
|
|
sigemptyset (&sat.sa_mask);
|
|
|
|
sat.sa_flags = 0;
|
|
|
|
sigaction (SIGINT, &sat, &oldAction);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* Initialize sample data */
|
|
|
|
memset (data, 0, sizeof (data));
|
|
|
|
for (i = 0; i < MAX_SAMPLES; i++)
|
|
|
|
{
|
|
|
|
samples[i] = &data[i];
|
|
|
|
}
|
|
|
|
|
2018-08-03 10:33:40 +02:00
|
|
|
participant = dds_create_participant (DDS_DOMAIN_DEFAULT, NULL, NULL);
|
2019-01-18 14:10:19 +01:00
|
|
|
if (participant < 0)
|
|
|
|
DDS_FATAL("dds_create_participant: %s\n", dds_strretcode(-participant));
|
2018-08-03 10:33:40 +02:00
|
|
|
|
|
|
|
if (use_listener)
|
|
|
|
{
|
2018-11-09 12:16:12 +01:00
|
|
|
listener = dds_create_listener(NULL);
|
2018-08-03 10:33:40 +02:00
|
|
|
dds_lset_data_available(listener, data_available);
|
|
|
|
}
|
|
|
|
|
|
|
|
(void)prepare_dds(&writer, &reader, &readCond, listener);
|
|
|
|
|
2018-04-10 17:03:59 +02:00
|
|
|
while (!dds_triggered (waitSet))
|
|
|
|
{
|
|
|
|
/* Wait for a sample from ping */
|
|
|
|
|
|
|
|
status = dds_waitset_wait (waitSet, wsresults, wsresultsize, waitTimeout);
|
2019-01-18 14:10:19 +01:00
|
|
|
if (status < 0)
|
|
|
|
DDS_FATAL("dds_waitset_wait: %s\n", dds_strretcode(-status));
|
2018-04-10 17:03:59 +02:00
|
|
|
|
|
|
|
/* Take samples */
|
2018-08-03 10:33:40 +02:00
|
|
|
if (listener == NULL) {
|
|
|
|
data_available (reader, 0);
|
2018-04-10 17:03:59 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef _WIN32
|
|
|
|
SetConsoleCtrlHandler (0, FALSE);
|
|
|
|
#else
|
|
|
|
sigaction (SIGINT, &oldAction, 0);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* Clean up */
|
2018-08-05 13:24:26 +02:00
|
|
|
finalize_dds(participant, data);
|
2018-04-10 17:03:59 +02:00
|
|
|
|
|
|
|
return EXIT_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2019-01-02 12:09:15 +01:00
|
|
|
static void finalize_dds(dds_entity_t pp, RoundTripModule_DataType xs[MAX_SAMPLES])
|
2018-04-10 17:03:59 +02:00
|
|
|
{
|
2018-08-03 10:33:40 +02:00
|
|
|
dds_return_t status;
|
2019-01-02 12:09:15 +01:00
|
|
|
status = dds_delete (pp);
|
2019-01-18 14:10:19 +01:00
|
|
|
if (status < 0)
|
|
|
|
DDS_FATAL("dds_delete: %s\n", dds_strretcode(-status));
|
2018-04-10 17:03:59 +02:00
|
|
|
for (unsigned int i = 0; i < MAX_SAMPLES; i++)
|
|
|
|
{
|
2019-01-02 12:09:15 +01:00
|
|
|
RoundTripModule_DataType_free (&xs[i], DDS_FREE_CONTENTS);
|
2018-04-10 17:03:59 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-01-02 12:09:15 +01:00
|
|
|
static dds_entity_t prepare_dds(dds_entity_t *wr, dds_entity_t *rd, dds_entity_t *rdcond, dds_listener_t *rdlist)
|
2018-04-10 17:03:59 +02:00
|
|
|
{
|
|
|
|
const char *pubPartitions[] = { "pong" };
|
|
|
|
const char *subPartitions[] = { "ping" };
|
|
|
|
dds_qos_t *qos;
|
|
|
|
dds_entity_t subscriber;
|
|
|
|
dds_entity_t publisher;
|
|
|
|
dds_entity_t topic;
|
|
|
|
dds_return_t status;
|
|
|
|
|
|
|
|
/* A DDS Topic is created for our sample type on the domain participant. */
|
|
|
|
|
|
|
|
topic = dds_create_topic (participant, &RoundTripModule_DataType_desc, "RoundTrip", NULL, NULL);
|
2019-01-18 14:10:19 +01:00
|
|
|
if (topic < 0)
|
|
|
|
DDS_FATAL("dds_create_topic: %s\n", dds_strretcode(-topic));
|
2018-04-10 17:03:59 +02:00
|
|
|
|
|
|
|
/* A DDS Publisher is created on the domain participant. */
|
|
|
|
|
2018-11-09 11:16:24 +01:00
|
|
|
qos = dds_create_qos ();
|
2018-04-10 17:03:59 +02:00
|
|
|
dds_qset_partition (qos, 1, pubPartitions);
|
|
|
|
|
|
|
|
publisher = dds_create_publisher (participant, qos, NULL);
|
2019-01-18 14:10:19 +01:00
|
|
|
if (publisher < 0)
|
|
|
|
DDS_FATAL("dds_create_publisher: %s\n", dds_strretcode(-publisher));
|
2018-11-09 11:16:24 +01:00
|
|
|
dds_delete_qos (qos);
|
2018-04-10 17:03:59 +02:00
|
|
|
|
|
|
|
/* A DDS DataWriter is created on the Publisher & Topic with a modififed Qos. */
|
|
|
|
|
2018-11-09 11:16:24 +01:00
|
|
|
qos = dds_create_qos ();
|
2018-04-10 17:03:59 +02:00
|
|
|
dds_qset_reliability (qos, DDS_RELIABILITY_RELIABLE, DDS_SECS(10));
|
|
|
|
dds_qset_writer_data_lifecycle (qos, false);
|
2019-01-02 12:09:15 +01:00
|
|
|
*wr = dds_create_writer (publisher, topic, qos, NULL);
|
2019-01-18 14:10:19 +01:00
|
|
|
if (*wr < 0)
|
|
|
|
DDS_FATAL("dds_create_writer: %s\n", dds_strretcode(-*wr));
|
2018-11-09 11:16:24 +01:00
|
|
|
dds_delete_qos (qos);
|
2018-04-10 17:03:59 +02:00
|
|
|
|
|
|
|
/* A DDS Subscriber is created on the domain participant. */
|
|
|
|
|
2018-11-09 11:16:24 +01:00
|
|
|
qos = dds_create_qos ();
|
2018-04-10 17:03:59 +02:00
|
|
|
dds_qset_partition (qos, 1, subPartitions);
|
|
|
|
|
|
|
|
subscriber = dds_create_subscriber (participant, qos, NULL);
|
2019-01-18 14:10:19 +01:00
|
|
|
if (subscriber < 0)
|
|
|
|
DDS_FATAL("dds_create_subscriber: %s\n", dds_strretcode(-subscriber));
|
2018-11-09 11:16:24 +01:00
|
|
|
dds_delete_qos (qos);
|
2018-04-10 17:03:59 +02:00
|
|
|
|
|
|
|
/* A DDS DataReader is created on the Subscriber & Topic with a modified QoS. */
|
|
|
|
|
2018-11-09 11:16:24 +01:00
|
|
|
qos = dds_create_qos ();
|
2018-04-10 17:03:59 +02:00
|
|
|
dds_qset_reliability (qos, DDS_RELIABILITY_RELIABLE, DDS_SECS(10));
|
2019-01-02 12:09:15 +01:00
|
|
|
*rd = dds_create_reader (subscriber, topic, qos, rdlist);
|
2019-01-18 14:10:19 +01:00
|
|
|
if (*rd < 0)
|
|
|
|
DDS_FATAL("dds_create_reader: %s\n", dds_strretcode(-*rd));
|
2018-11-09 11:16:24 +01:00
|
|
|
dds_delete_qos (qos);
|
2018-04-10 17:03:59 +02:00
|
|
|
|
|
|
|
waitSet = dds_create_waitset (participant);
|
2019-01-02 12:09:15 +01:00
|
|
|
if (rdlist == NULL) {
|
|
|
|
*rdcond = dds_create_readcondition (*rd, DDS_ANY_STATE);
|
|
|
|
status = dds_waitset_attach (waitSet, *rdcond, *rd);
|
2019-01-18 14:10:19 +01:00
|
|
|
if (status < 0)
|
|
|
|
DDS_FATAL("dds_waitset_attach: %s\n", dds_strretcode(-status));
|
2018-08-03 10:33:40 +02:00
|
|
|
} else {
|
2019-01-02 12:09:15 +01:00
|
|
|
*rdcond = 0;
|
2018-08-03 10:33:40 +02:00
|
|
|
}
|
2018-04-10 17:03:59 +02:00
|
|
|
status = dds_waitset_attach (waitSet, waitSet, waitSet);
|
2019-01-18 14:10:19 +01:00
|
|
|
if (status < 0)
|
|
|
|
DDS_FATAL("dds_waitset_attach: %s\n", dds_strretcode(-status));
|
2018-04-10 17:03:59 +02:00
|
|
|
|
|
|
|
printf ("Waiting for samples from ping to send back...\n");
|
|
|
|
fflush (stdout);
|
|
|
|
|
|
|
|
return participant;
|
|
|
|
}
|