#include "example.h"
#define BUF_SA3_RX 0
#define BUF_SA3_TX 1
#define BUF_SA5_RX 2
#define BUF_SA5_TX 3
#define RT_ADRS 5
#define LOCAL
int main(void)
{
uint32 rc;
uint64 deviceCount=0;
uint64 moduleCount=0;
uint64 channelCount=0;
HMXF_SERVER server=0;
HMXF_DEVICE device=0;
HMXF_MODULE module=0;
HMXF_CHANNEL bc=0;
HMXF_CHANNEL rt=0;
HMXF_BUFFER bcBufferTx[4];
HMXF_BUFFER bcBufferRx=0;
HMXF_BUFFER rtBuffer[4];
MXF_MSGID_MIL1553 bcMsgID[4]={{MXF_MIL1553_MSGTYPE_RX,RT_ADRS,3,0},{MXF_MIL1553_MSGTYPE_TX,RT_ADRS,3,0},{MXF_MIL1553_MSGTYPE_RX,RT_ADRS,5,0},{MXF_MIL1553_MSGTYPE_TX,RT_ADRS,5,0}};
MXF_MSGID_MIL1553 rtMsgID[4]={{MXF_MIL1553_MSGTYPE_RX,0,3,0},{MXF_MIL1553_MSGTYPE_TX,0,3,0},{MXF_MIL1553_MSGTYPE_RX,0,5,0},{MXF_MIL1553_MSGTYPE_TX,0,5,0}};
uint32 txBufferSize=0;
uint32 rxBufferSize=0;
uint64 bus=MXF_MIL1553_BUS_A|MXF_MIL1553_BUS_B;
uint64 rxAcqStatus=0;
uint64 msgCount=0;
uint64 byteCount=0;
uint64 rxRec;
uint32 loop=0;
uint64 address, subAddress, dir, wordCount, indexBuffer;
uint32 data;
uint32 msg;
char errorString[200];
#ifdef LOCAL
#else
#endif
if(!rc)
{
printf("Starting ...\n\r");
}
if(!rc)
if(!rc && deviceCount)
if(!rc && moduleCount)
if(!rc && !channelCount)
rc = MAXT_ERROR_NOT_FOUND;
if(!rc)
#ifdef LOOPBACK
if(!rc)
#endif
if(!rc)
{
txBufferSize = 1024;
for(msg=0; msg<4 && !rc; msg++)
{
if(!rc)
if(!rc)
}
if(!rc)
{
if(!txBuffer)
rc = MAXT_ERROR_MEM;
}
}
if(!rc)
{
rxBufferSize = 10*1024;
if(!rc)
{
if(!rxBuffer)
rc = MAXT_ERROR_MEM;
}
}
if(!rc)
if(!rc)
{
memset(&err, 0, sizeof(err));
err.
errors[33] = (RT_ADRS<<11)+1;
if(!rc)
}
if(!rc)
{
memset(minorFrame, 0, sizeof(minorFrame));
memset(&mfProp, 0, sizeof(mfProp));
mfProp.
options = MXF_MIL1553_TXPERIODIC_MJRFRAME_MINOR_PROPERTIES_OPT_BRANCH_GOTO;
rc =
mxfMIL1553CommandCompose(bcMsgID[BUF_SA3_RX].address, bcMsgID[BUF_SA3_RX].subAddress, bcMsgID[BUF_SA3_RX].type, 2, &minorFrame[0].command);
minorFrame[0].
buffer = bcBufferTx[BUF_SA3_RX];
if(!rc)
{
rc =
mxfMIL1553CommandCompose(bcMsgID[BUF_SA3_TX].address, bcMsgID[BUF_SA3_TX].subAddress, bcMsgID[BUF_SA3_TX].type, 2, &minorFrame[1].command);
if(!rc)
{
minorFrame[1].
options = MXF_MIL1553_TXPERIODIC_MJRFRAME_MSG_OPT_DELAY;
minorFrame[1].
buffer = bcBufferTx[BUF_SA3_TX];
minorFrame[1].
delay = 8000;
minorFrame[1].
condData = (uint16)(bcMsgID[BUF_SA3_TX].address<<11);
}
if(!rc)
}
}
if(!rc)
{
memset(minorFrame, 0, sizeof(minorFrame));
rc =
mxfMIL1553CommandCompose(bcMsgID[BUF_SA5_RX].address, bcMsgID[BUF_SA5_RX].subAddress, bcMsgID[BUF_SA5_RX].type, 3, &minorFrame[0].command);
minorFrame[0].
buffer = bcBufferTx[BUF_SA5_RX];
if(!rc)
{
rc =
mxfMIL1553CommandCompose(bcMsgID[BUF_SA5_TX].address, bcMsgID[BUF_SA5_TX].subAddress, bcMsgID[BUF_SA5_TX].type, 3, &minorFrame[1].command);
if(!rc)
{
minorFrame[1].
options = MXF_MIL1553_TXPERIODIC_MJRFRAME_MSG_OPT_GAP;
minorFrame[1].
buffer = bcBufferTx[BUF_SA5_TX];
minorFrame[1].
delay = 8000;
minorFrame[1].
condData = (uint16)(bcMsgID[BUF_SA3_TX].address<<11);
}
}
if(!rc)
}
if(!rc)
{
txRec1553->
data[0] = 0x0000;
txRec1553->
data[1] = 0x0000;
txRec1553->
data[2] = 0x1111;
}
if(!rc)
{
txRec1553->
data[0] = 0x0000;
txRec1553->
data[1] = 0xFFFF;
txRec1553->
data[2] = 0xEEEE;
txRec1553->
data[3] = 0xDDDD;
}
if(!rc)
{
txRec1553->
data[0] = 0x0000;
txRec1553->
data[1] = 0x1234;
txRec1553->
data[2] = 0x5678;
if(!rc)
{
txRec1553->
control = MXF_MIL1553_TXPERIODIC_REC_CTRL_ERROR_INJ;
txRec1553->
data[0] = 0x0000;
txRec1553->
data[1] = 0x9ABC;
txRec1553->
data[2] = 0xDEF0;
}
if(!rc)
if(!rc)
{
txRec1553->
data[0] = 0x0000;
txRec1553->
data[1] = 0x1234;
txRec1553->
data[2] = 0x5678;
}
if(!rc)
}
if(!rc)
{
txRec1553->
data[0] = 0x0000;
txRec1553->
data[1] = 0x4444;
txRec1553->
data[2] = 0x5555;
txRec1553->
data[3] = 0x6666;
}
if(!rc)
{
printf("Starting BC and RT\n\r");
}
if(!rc)
if(!rc)
if(!rc)
{
do
{
rc =
mxfMIL1553RxAcqRead(bcBufferRx, 0, rxBufferSize, &rxAcqStatus, &msgCount, &byteCount, rxBuffer);
for(rxRec=0; rxRec<msgCount && !rc; rxRec++)
{
if(!rc)
{
if(!rc)
{
printf(
"\n\r%llu:\t", rxRec1553->
timeTag);
{
case MXF_MIL1553_MSGINFO_TYPE_BCRT:
printf(
"BC to RT%llu SA%llu WC%llu (0x%04x)\n\r", address, subAddress, wordCount, rxRec1553->
data[0]);
printf(
"\t\tRT status: 0x%04x\n\r", rxRec1553->
data[msgInfo.
statusIndex[0]]);
break;
case MXF_MIL1553_MSGINFO_TYPE_RTBC:
printf(
"RT%llu SA%llu WC%llu to BC (0x%04x)\n\r", address, subAddress, wordCount, rxRec1553->
data[0]);
printf(
"\t\tRT status: 0x%04x\n\r", rxRec1553->
data[msgInfo.
statusIndex[0]]);
printf("\t\tRT data:");
for(data=0; data<msgInfo.dataWordCount; data++)
{
if(data && !(data%4))
printf("\n\r\t\t\t");
}
printf("\n\r");
break;
case MXF_MIL1553_MSGINFO_TYPE_MODECODE_TXDATA:
printf(
"BC Mode Command %llu to RT%llu SA%llu (0x%04x)\n\r", wordCount, address, subAddress, rxRec1553->
data[0]);
{
printf(
"\t\tRT status: 0x%04x\n\r", rxRec1553->
data[msgInfo.
statusIndex[0]]);
printf(
"\t\tRT data: 0x%04x\n\r", rxRec1553->
data[msgInfo.
dataIndex]);
}
break;
}
}
}
}
loop++;
}while(loop < 10);
}
if(!rc)
{
if (!rc)
}
if(!rc)
if(!rc)
{
printf("Stopping BC and RT\n\r");
for(msg=0; msg<4 && !rc; msg++)
{
if(!rc)
}
}
printf("Terminating\n");
if(txBuffer)
free(txBuffer);
if(rxBuffer)
free(rxBuffer);
if(rc)
{
sprintf (errorString,"ERROR # 0x%08X", rc);
printf("%s\n\r", errorString);
}
for (indexBuffer = 0; indexBuffer < 4; indexBuffer++)
{
if (bcBufferTx[indexBuffer])
{
if (rc)
printf("Free buffer failed !\n\r");
}
}
for (indexBuffer = 0; indexBuffer < 4; indexBuffer++)
{
if (rtBuffer[indexBuffer])
{
if (rc)
printf("Free buffer failed !\n\r");
}
}
if(bcBufferRx)
{
if (rc)
printf("Free buffer failed !\n\r");
}
printf("\n\rPress enter to terminate\n\r");
getchar();
return 0;
}