#include "example.h"
#include <time.h>
#define LOCAL
#define MAX_TX_RECORDS_TO_TRANSMIT 100
#define BUFFER_SIZE MAX_TX_RECORDS_TO_TRANSMIT*sizeof(MXF_MIL1553_DATAREC) // Space for at least 100 records
int main(void)
{
uint32 rc;
HMXF_SERVER server;
uint64 count=0;
HMXF_CHANNEL bm=0;
HMXF_CHANNEL bc=0;
HMXF_BUFFER bmBuffer=0;
HMXF_BUFFER bcBuffer=0;
uint64 dev, mod, port;
HMXF_COND_LIST condList=0;
uint16 triggerData;
#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)
rc =
mxfChannelAllGet(server, MXF_CLASS_MIL1553, MXF_SCLASS_BM_CHANNEL, MXF_MODULE_ALL, 1, &count, &bm);
if (!rc && count)
rc =
mxfChannelAllGet(server, MXF_CLASS_MIL1553, MXF_SCLASS_BC_CHANNEL, MXF_MODULE_ALL, 1, &count, &bc);
if(!rc && !count)
rc = MAXT_ERROR_NOT_FOUND;
if (!rc)
if (!rc)
{
if (!rc)
printf("Acquisition Channel (BM) location=%llu.%llu.%llu\n", dev, mod, port);
}
if (!rc)
{
if (!rc)
printf("Transmitter Channel (BC) location=%llu.%llu.%llu\n", dev, mod, port);
}
#ifdef LOOPBACK
if (!rc)
#endif
if (!rc)
if(!rc)
if (!rc)
{
if (!rec1553)
rc = MAXT_ERROR_MEM;
}
if (!rc)
if(!rc)
{
condParam.
mask = 0x0000ffff;
condParam.
data = triggerData;
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 = TransmitAperiodicData(bcBuffer, rec1553);
if (!rc)
{
rc = ReadAcquisitionData(bmBuffer, rec1553);
}
}
if (!rc)
if (!rc)
{
if (!rc)
printf("\nAcquisition stopped\n\r");
}
if(!rc)
if (rc)
{
char buffer[256];
printf("%s\n", buffer);
}
if(bmBuffer)
{
if (rc)
printf("Free buffer failed !\n\r");
}
if(bcBuffer)
{
if (rc)
printf("Free buffer failed !\n\r");
}
printf("\nTerminating\n");
if (rec1553)
free(rec1553);
printf("\nPress enter to terminate\n");
getchar();
return rc;
}
{
uint32 rc;
uint64 data;
for(data=0; data<MAX_TX_RECORDS_TO_TRANSMIT; data++)
{
}
printf("Transmitting ...\n");
rc =
mxfTxAperiodicWrite(bcBuffer, MXF_TXAPERIODIC_FLAG_DEFAULT, 0, MAX_TX_RECORDS_TO_TRANSMIT, rec1553);
if(!rc)
return rc;
}
{
uint64 status, msgsCount, bytesCount;
uint64 j, trigTime=0;
uint32 rc;
time_t timeTemp;
struct tm * ptm;
char szTime[1024];
uint64 msec, usec;
uint64 word;
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:%03llu:%03llu\n", szTime, msec, usec);
}
}
else
printf("Trigger not fired\n");
}
rc =
mxfRxAcqRead(bmBuffer, 0, BUFFER_SIZE, &status, &msgsCount, &bytesCount, rec1553);
for (j=0; j<msgsCount && !rc; j++)
{
printf(
" %02llu: Timetag=%012llu, Size=%u\n Data=", j, rec->
timeTag, rec->
dataSize);
for(word=0; word<rec->
dataSize/2; word++)
printf(
"%04X ", rec->
data[word]);
printf(
"%s\n", trigTime==rec->
timeTag?
"*":
"");
}
return rc;
}