#include "example.h"
#define LOOPBACK
#define LOCAL
#define BUFFER_SIZE 4096 // 4KB
#define MAX_TX_RECORDS_TO_TRANSMIT 8
#define BLOCKCOUNT 6
uint32 initHandler(HMXF_SERVER server, uint64 deviceIndex, uint64 moduleIndex, uint64 channelIndex, uint64 attrib, uint64* value);
uint32 WaitQueueEmpty(HMXF_BUFFER txBuffer);
uint32 StartAperiodicTransmissionDefault(HMXF_BUFFER txBuffer,
MXF_CSDB_DATAREC *recCsdb);
uint32 StartAperiodicTransmissionAbsolute(HMXF_DEVICE device, HMXF_BUFFER txBuffer,
MXF_CSDB_DATAREC *recCsdb);
uint32 StartAperiodicTransmissionRecordAbsolute(HMXF_DEVICE device, HMXF_BUFFER txBuffer,
MXF_CSDB_DATAREC *recCsdb);
uint32 StartAperiodicTransmissionRecordRelative(HMXF_BUFFER txBuffer,
MXF_CSDB_DATAREC *recCsdb);
int main(void)
{
uint32 rc;
HMXF_SERVER server;
HMXF_DEVICE device=0;
HMXF_MODULE module=0;
uint64 count=0;
HMXF_CHANNEL rxChannel=0;
HMXF_CHANNEL txChannel=0;
HMXF_BUFFER rxBuffer=0;
HMXF_BUFFER txBuffer=0;
uint64 dev, mod, port;
#ifdef LOCAL
#else
#endif
if (rc)
{
printf("Failed to connect; rc=0x%08x", rc);
printf("\nPress a key to terminate\n");
getchar();
return 0;
}
printf("\nStarting\n");
if(!rc)
if (!rc)
if (!rc)
if (!rc && count)
if (!rc && count)
if(!rc && !count)
rc = MAXT_ERROR_NOT_FOUND;
if (!rc)
if (!rc)
{
if (!rc)
printf("Acquisition Channel (RX) location=%"PRIu64".%"PRIu64".%"PRIu64"\n", dev, mod, port);
}
if (!rc)
{
if (!rc)
printf("Transmitter Channel (TX) location=%"PRIu64".%"PRIu64".%"PRIu64"\n", dev, mod, port);
}
#ifdef LOOPBACK
if (!rc)
#endif
if(!rc)
if(!rc)
if (!rc)
if (!rc)
if (!rc)
{
if (!recCsdb)
rc = MAXT_ERROR_MEM;
}
if (!rc)
if (!rc)
{
if (!rc)
printf("\nAcquisition started\n\r");
}
if (!rc)
{
rc = StartAperiodicTransmissionDefault(txBuffer, recCsdb);
if (!rc)
rc = ReadAcquisitionData(rxBuffer, recCsdb);
if (!rc)
rc = StartAperiodicTransmissionAbsolute(device, txBuffer, recCsdb);
if (!rc)
rc = ReadAcquisitionData(rxBuffer, recCsdb);
if (!rc)
rc = StartAperiodicTransmissionRecordAbsolute(device, txBuffer, recCsdb);
if (!rc)
rc = ReadAcquisitionData(rxBuffer, recCsdb);
if (!rc)
rc = StartAperiodicTransmissionRecordRelative(txBuffer, recCsdb);
if (!rc)
rc = ReadAcquisitionData(rxBuffer, recCsdb);
}
if (!rc)
if (!rc)
{
if (!rc)
printf("\nAcquisition stopped\n\r");
}
if (rc)
{
char buffer[256];
printf("%s\n", buffer);
}
printf("\nTerminating\n");
if (rxBuffer)
if(txBuffer)
if (recCsdb)
free(recCsdb);
printf("\nPress enter to terminate\n");
getchar();
return rc;
}
{
uint64 status, msgsCount, bytesCount;
uint64 j;
uint32 rc, data;
rc =
mxfCSDBRxAcqRead(rxBuffer, 0, BUFFER_SIZE, &status, &msgsCount, &bytesCount, recCsdb);
if(!rc)
{
printf("Read %"PRIu64" messages\n\r", msgsCount);
for (j=0; !rc && j<msgsCount; j++)
{
printf(
"%02"PRIu64
": Timetag %"PRIu64
" - ", j, recPtr->
timeTag);
for(data=0; data<6; data++)
printf(
"%02x", recPtr->
data[data]);
printf("\n\r");
}
}
if(rc)
printf("Acquisition read failed; rc=0x%08x\n\r", rc);
return rc;
}
uint32 WaitQueueEmpty(HMXF_BUFFER txBuffer)
{
uint64 msgCount, usedBytes, freeBytes;
uint32 rc;
do
{
if (rc)
return rc;
}while (msgCount!=0);
return MAXT_SUCCESS;
}
uint32 StartAperiodicTransmissionDefault(HMXF_BUFFER txBuffer,
MXF_CSDB_DATAREC *recCsdb)
{
uint64 dataIdx;
uint32 record;
uint64 delay100ms = 100000;
uint32 rc;
printf("\nAperiodic transmission (Relative Start Time-Default)\n");
rec = recCsdb;
for (record=0; record<MAX_TX_RECORDS_TO_TRANSMIT; record++)
{
if(record == 0)
{
for(dataIdx=0; dataIdx<BLOCKCOUNT; dataIdx++)
rec->
data[dataIdx] = 0xA5;
}
else
{
for(dataIdx=2; dataIdx<BLOCKCOUNT; dataIdx++)
rec->
data[dataIdx] = (uint8)(0x11*record);
}
}
rc =
mxfCSDBTxAperiodicWrite(txBuffer, MXF_TXAPERIODIC_FLAG_DEFAULT, delay100ms, MAX_TX_RECORDS_TO_TRANSMIT, recCsdb);
if (!rc)
rc = WaitQueueEmpty(txBuffer);
return rc;
}
uint32 StartAperiodicTransmissionAbsolute(HMXF_DEVICE device, HMXF_BUFFER txBuffer,
MXF_CSDB_DATAREC *recCsdb)
{
uint64 dataIdx;
uint32 record, rc;
uint32 delay100ms = 100000;
uint64 currentTime;
if (rc)
return rc;
printf("\nAperiodic transmission (Absolute)\n");
rec = recCsdb;
for (record=0; record<MAX_TX_RECORDS_TO_TRANSMIT; record++)
{
if(record == 0)
{
for(dataIdx=0; dataIdx<BLOCKCOUNT; dataIdx++)
rec->
data[dataIdx] = 0xA5;
}
else
{
for(dataIdx=2; dataIdx<BLOCKCOUNT; dataIdx++)
rec->
data[dataIdx] = (uint8)record;
}
}
rc =
mxfCSDBTxAperiodicWrite(txBuffer, MXF_TXAPERIODIC_FLAG_ABSOLUTE_START_TIME, currentTime+delay100ms, MAX_TX_RECORDS_TO_TRANSMIT, recCsdb);
if (!rc)
rc = WaitQueueEmpty(txBuffer);
return rc;
}
uint32 StartAperiodicTransmissionRecordAbsolute(HMXF_DEVICE device, HMXF_BUFFER txBuffer,
MXF_CSDB_DATAREC *recCsdb)
{
uint64 dataIdx;
uint32 record;
uint64 currentTime;
uint32 rc;
printf("\nAperiodic transmission (Absolute with timetag)\n");
if (rc)
return rc;
currentTime+=100000;
rec = recCsdb;
for (record=0; record<MAX_TX_RECORDS_TO_TRANSMIT; record++)
{
if(record == 0)
{
rec->
timeTag = currentTime+((record+1)*10000LL);
for(dataIdx=0; dataIdx<BLOCKCOUNT; dataIdx++)
rec->
data[dataIdx] = 0xA5;
}
else
{
rec->
timeTag = currentTime+((record+1)*10000LL);
for(dataIdx=2; dataIdx<BLOCKCOUNT; dataIdx++)
rec->
data[dataIdx] = (uint8)(2*record);
}
}
rc =
mxfCSDBTxAperiodicWrite(txBuffer, MXF_TXAPERIODIC_FLAG_USE_RECORD_ABSOLUTE_TIME, 0, MAX_TX_RECORDS_TO_TRANSMIT, recCsdb);
if (!rc)
rc = WaitQueueEmpty(txBuffer);
return rc;
}
uint32 StartAperiodicTransmissionRecordRelative(HMXF_BUFFER txBuffer,
MXF_CSDB_DATAREC *recCsdb)
{
uint64 dataIdx;
uint32 record;
uint64 currentTime;
uint32 rc;
printf("\nAperiodic transmission (Record Relative)\n");
rec = recCsdb;
for (record=0, currentTime=100000; record<MAX_TX_RECORDS_TO_TRANSMIT; record++)
{
if(record == 0)
{
rec->
timeTag = currentTime+((record+1)*10000LL);
for(dataIdx=0; dataIdx<BLOCKCOUNT; dataIdx++)
rec->
data[dataIdx] = 0xA5;
}
else
{
rec->
timeTag = currentTime+((record+1)*10000LL);
for(dataIdx=2; dataIdx<BLOCKCOUNT; dataIdx++)
rec->
data[dataIdx] = (uint8)(3*record);
}
}
rc =
mxfCSDBTxAperiodicWrite(txBuffer, MXF_TXAPERIODIC_FLAG_USE_RECORD_RELATIVE_TIME, 0, MAX_TX_RECORDS_TO_TRANSMIT, recCsdb);
if (!rc)
rc = WaitQueueEmpty(txBuffer);
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;
}