#include "example.h"
#include <time.h>
#define LOOPBACK
#define LOCAL
#define BUFFER_SIZE 1*1024*1024 // 1 MiB
#define LABEL 0x7
#define SI 0
#define BLOCKCOUNT 6
uint32 PeriodicScheduling(HMXF_CHANNEL txChannel, HMXF_BUFFER *txBuffer,
MXF_CSDB_DATAREC *recCsdb);
uint32 initHandler(HMXF_SERVER server, uint64 deviceIndex, uint64 moduleIndex, uint64 channelIndex, uint64 attrib, uint64* value);
int main(void)
{
uint32 rc;
HMXF_SERVER server;
HMXF_DEVICE device=0;
HMXF_MODULE module=0;
HMXF_CHANNEL rxChannel=0, txChannel=0;
HMXF_BUFFER rxBuffer=0, txBuffer[2]={0,0};
uint64 count=0;
HMXF_COND_LIST condList=0;
#ifdef LOCAL
#else
#endif
if(rc!=MAXT_SUCCESS)
{
printf("Failed to connect; rc=0x%08x", rc);
getchar();
return 0;
}
printf("\n\rStarting\n\r");
if(!rc)
if(!rc)
if(!rc)
if(!rc)
rc =
mxfChannelAllGet(server, MXF_CLASS_CSDB, MXF_SCLASS_RX_CHANNEL, MXF_MODULE_ASYNC_EH, 1, &count, &rxChannel);
if (!rc && count)
rc =
mxfChannelAllGet(server, MXF_CLASS_CSDB, MXF_SCLASS_TX_CHANNEL, MXF_MODULE_ASYNC_EH, 1, &count, &txChannel);
if(!rc && !count)
rc = MAXT_ERROR_NOT_FOUND;
if(!rc)
if(!rc)
if(!rc)
if(!rc)
if(!rc)
if(!rc)
if(!rc)
if(!rc)
#ifdef LOOPBACK
if(!rc)
#endif
if (!rc)
if(!rc)
{
if(!hostBuffer)
rc = MAXT_ERROR_MEM;
}
if(!rc)
if(!rc)
if(!rc)
if (!rc)
if(!rc)
{
condParam.
mask = 0x000083ff;
condParam.
data = (SI << 8) | LABEL;
condParam.
options = MXF_RXACQ_TRIG_COND_RDATA_OPTIONS_EQUAL;
}
if(!rc)
if (!rc)
if (!rc)
{
if (!rc)
printf("\nAcquisition started\n\r");
}
if (!rc)
{
rc = PeriodicScheduling(txChannel, txBuffer, hostBuffer);
if (!rc)
{
rc = ReadAcquisitionData(rxBuffer, hostBuffer);
}
}
if (!rc)
if (!rc)
{
if (!rc)
printf("\nAcquisition stopped\n\r");
}
if(!rc)
if (rc)
{
char buffer[256];
printf("%s\n", buffer);
}
printf("\nTerminating\n");
if (device)
if (hostBuffer)
free(hostBuffer);
printf("\nPress enter to terminate\n");
getchar();
return rc;
}
uint32 PeriodicScheduling(HMXF_CHANNEL txChannel, HMXF_BUFFER *txBuffer,
MXF_CSDB_DATAREC *recCsdb)
{
HMXF_SCHED schedule;
HMXF_SCHED_MSG msg=0;
uint32 rc;
uint64 i;
if(!rc)
if(!rc)
if(!rc)
{
for (i=0; i<BLOCKCOUNT; i++)
recCsdb->
data[0] = LABEL;
recCsdb->
data[1] = 0x80 | SI;
for (i=2; i<BLOCKCOUNT; i++)
recCsdb->
data[i]= (uint8)i;
}
if(!rc)
{
printf("Running periodic transmission, please wait...\n\r");
}
if(!rc)
{
}
if(!rc)
{
}
if(!rc)
printf("\n\rTransmission stopped\n\r");
return rc;
}
{
uint64 status, msgsCount, bytesCount;
uint64 i, j, trigTime=0;
uint32 rc;
time_t timeTemp;
struct tm * ptm;
char szTime[1024];
uint64 msec, usec;
if(!rc)
{
if(status & MXF_RXACQ_STATUS_TRIG_OCCURRED)
{
if(!rc)
{
timeTemp = trigTime/1000000;
ptm = localtime(&timeTemp);
strftime(szTime, sizeof(szTime), "%Y-%m-%d %H:%M:%S", ptm);
usec = trigTime%1000;
timeTemp = trigTime/1000;
msec = timeTemp%1000;
printf("Event triggered at %s:%03"PRIu64":%03"PRIu64"\n", szTime, msec, usec);
}
}
else
printf("Trigger not fired\n");
}
rc =
mxfRxAcqRead(rxBuffer, 0, BUFFER_SIZE, &status, &msgsCount, &bytesCount, recCsdb);
for (j=0; j<msgsCount && !rc; j++)
{
printf(
"%02"PRIu64
": Timetag=%016"PRIu64
": CSDB data=[ ", j, rec->
timeTag);
for (i=0; i<BLOCKCOUNT; i++)
printf(
"0x%02X ", rec->
data[i]);
printf(
"] %s\n\r", trigTime==rec->
timeTag?
"*":
"");
}
return rc;
}
uint32 initHandler(HMXF_SERVER server, uint64 deviceIndex, uint64 moduleIndex, uint64 channelIndex, uint64 attrib, uint64* value)
{
HMXF_DEVICE device;
uint32 rc;
server=server;
deviceIndex=deviceIndex;
if(attrib == KMXF_CHANNEL_CLASS)
{
if (!rc)
if(!rc && (deviceInfo.
modules[moduleIndex].
type == MXF_MODULE_ASYNC_EH))
{
if ((channelIndex == 0) || (channelIndex == deviceInfo.
modules[moduleIndex].
txCount))
{
*value = MXF_CLASS_CSDB;
return TRUE;
}
}
}
return FALSE;
}