📄 tcp2_standalone_mode_example.c
字号:
tcp2_configEdma (hdDecisionBuffer);
/* Disable cahnnels and clear the EDMA event registers */
CSL_edma3HwChannelControl (hChannel, CSL_EDMA3_CMD_CHANNEL_DISABLE, NULL);
CSL_edma3HwChannelControl (hChannel1, CSL_EDMA3_CMD_CHANNEL_DISABLE, NULL);
CSL_edma3HwChannelControl (hChannel, CSL_EDMA3_CMD_CHANNEL_CLEAR, NULL);
CSL_edma3HwChannelControl (hChannel1, CSL_EDMA3_CMD_CHANNEL_CLEAR, NULL);
/* Enable Channel */
CSL_edma3HwChannelControl (hChannel, CSL_EDMA3_CMD_CHANNEL_ENABLE, NULL);
CSL_edma3HwChannelControl (hChannel1, CSL_EDMA3_CMD_CHANNEL_ENABLE, NULL);
/* reset and start the TCP */
TCP2_reset ();
TCP2_start ();
/* wait for the status to indicate hard decisions are read */
while (0xA != TCP2_statTcpState ());
/* compare the hard decisions and check if they are as expected */
for (cnt = 0; cnt < numHd; cnt++) {
printf ("Hard decisions : 0x%x \n", hdDecisionBuffer [cnt]);
} /* end of for */
/* free the allocated memory */
free (hdDecisionBuffer);
/* Disable cahnnels and clear the EDMA event registers */
CSL_edma3HwChannelControl (hChannel, CSL_EDMA3_CMD_CHANNEL_DISABLE, NULL);
CSL_edma3HwChannelControl (hChannel1, CSL_EDMA3_CMD_CHANNEL_DISABLE, NULL);
CSL_edma3HwChannelControl (hChannel, CSL_EDMA3_CMD_CHANNEL_CLEAR, NULL);
CSL_edma3HwChannelControl (hChannel1, CSL_EDMA3_CMD_CHANNEL_CLEAR, NULL);
/* clear the EDMA error registers */
chErrClear.missed = TRUE;
chErrClear.secEvt = TRUE;
CSL_edma3HwChannelControl (hChannel, CSL_EDMA3_CMD_CHANNEL_CLEARERR,
&chErrClear);
CSL_edma3HwChannelControl (hChannel1, CSL_EDMA3_CMD_CHANNEL_CLEARERR,
&chErrClear);
printf ("Example complete \n");
}
/*
* =============================================================================
* @func tcp2_configEdma
* @desc
* Configures EDMA channels 30 and 31.
* For channel 31 there are 3 param entries(0, 1 and 2) which are linked.
* Link 0 transfers the TCP2 input configuration register values.
* Link 1 transfer the systematics and parity data.
* Link 2 transfers the interleaver data
* For channel 30 there is 1 param entry (3).
* Link 3 transfers the Hard decisions.
*
*
* @eg
* tcp2_configEdma();
* =============================================================================
*/
Uint16 tcp2_configEdma (
Uint32 *hdDecisionBuffer
)
{
volatile Uint16 count;
CSL_Status chStatus, chStatus1;
CSL_edma3Init(&context);
CSL_edma3Open(&edmaObj,CSL_EDMA3,NULL,&chStatus);
/* Channel Configuration for TCPXEVT event */
/* Channel Open */
chParam.regionNum = CSL_EDMA3_REGION_GLOBAL;
chParam.chaNum = CSL_EDMA3_CHA_TCP2XEVT;
hChannel = CSL_edma3ChannelOpen(&ChObj, CSL_EDMA3, &chParam, &chStatus);
if ((chStatus != CSL_SOK) || (hChannel == NULL)) {
printf("Error in EDMA channel open function\n");
return 0;
}
/* Channel Setup for PARAM entry 0 */
if (CSL_SOK != CSL_edma3HwChannelSetupParam(hChannel, 0 )){
printf("Error is EDMA channel setup for channel #31\n");
return 0;
}
if (CSL_SOK != CSL_edma3HwChannelSetupQue(hChannel, CSL_EDMA3_QUE_0)) {
printf("Error is EDMA channel setup for channel #31\n");
return 0;
}
/* Setup EDMA to transmit the input configuration parameters */
hParam[0] = CSL_edma3GetParamHandle (hChannel, 0, &chStatus);
myParamSetup.option = CSL_EDMA3_OPT_MAKE(FALSE, FALSE, FALSE, FALSE, 0,
CSL_EDMA3_TCC_NORMAL,
CSL_EDMA3_FIFOWIDTH_NONE,
FALSE,CSL_EDMA3_SYNC_A,
CSL_EDMA3_ADDRMODE_INCR,
CSL_EDMA3_ADDRMODE_INCR);
myParamSetup.srcAddr = (Uint32)&configIc;
myParamSetup.srcDstBidx = CSL_EDMA3_BIDX_MAKE(1, 1);
myParamSetup.dstAddr = (Uint32)CSL_TCP2_CFG_REGS;
myParamSetup.linkBcntrld = CSL_EDMA3_LINKBCNTRLD_MAKE(0x20, 0); /* offset
to the next PARAM entry */
myParamSetup.aCntbCnt = CSL_EDMA3_CNT_MAKE(sizeof (configIc), 1);
myParamSetup.cCnt = 1;
if (CSL_SOK != CSL_edma3ParamSetup (hParam[0], &myParamSetup)) {
printf("Error in EDMA PARAM setup for entry #0\n");
return 0;
}
/* Setup link to transmit systematics and parity data using param 1*/
hParam[1] = CSL_edma3GetParamHandle (hChannel, 1, &chStatus);
myParamSetup.option = CSL_EDMA3_OPT_MAKE(FALSE, FALSE, FALSE, FALSE, 0,
CSL_EDMA3_TCC_NORMAL,
CSL_EDMA3_FIFOWIDTH_NONE,
FALSE,CSL_EDMA3_SYNC_A,
CSL_EDMA3_ADDRMODE_INCR,
CSL_EDMA3_ADDRMODE_INCR);
myParamSetup.srcAddr = (Uint32)sysParData;
myParamSetup.srcDstBidx = CSL_EDMA3_BIDX_MAKE(1, 1);
myParamSetup.dstAddr = (Uint32)CSL_TCP2_X0_MEM;
/* linking to the offset to the next PARAM entry */
myParamSetup.linkBcntrld = CSL_EDMA3_LINKBCNTRLD_MAKE(0x40, 0);
/* length of the systematic and parity data to be transferred */
myParamSetup.aCntbCnt = CSL_EDMA3_CNT_MAKE(frameLength * 4, 1);
myParamSetup.cCnt = 1;
if (CSL_SOK != CSL_edma3ParamSetup (hParam[1], &myParamSetup)) {
printf("Error in EDMA paRam setup for entry #1\n");
return 0;
}
/* Setup link to transmit interleaver data */
hParam[2] = CSL_edma3GetParamHandle (hChannel, 2, &chStatus); /* param entry 2 */
myParamSetup.option = CSL_EDMA3_OPT_MAKE(FALSE, FALSE, FALSE, FALSE, 0,
CSL_EDMA3_TCC_NORMAL,
CSL_EDMA3_FIFOWIDTH_NONE,
FALSE,CSL_EDMA3_SYNC_A,
CSL_EDMA3_ADDRMODE_INCR,
CSL_EDMA3_ADDRMODE_INCR);
myParamSetup.srcAddr = (Uint32)interleaverTbl;
myParamSetup.srcDstBidx = CSL_EDMA3_BIDX_MAKE(1, 1);
myParamSetup.dstAddr = (Uint32)CSL_TCP2_I0_MEM;
myParamSetup.linkBcntrld = CSL_EDMA3_LINKBCNTRLD_MAKE (
CSL_EDMA3_LINK_NULL, 0);
myParamSetup.aCntbCnt = CSL_EDMA3_CNT_MAKE(88, 1);
/* number of bytes of interleaver data */
myParamSetup.cCnt = 1;
if (CSL_SOK != CSL_edma3ParamSetup (hParam[2], &myParamSetup)) {
printf("Error in EDMA PARAM setup for entry #2\n");
return 0;
}
/* Receive Channel Open */
chParam1.regionNum = CSL_EDMA3_REGION_GLOBAL;
chParam1.chaNum = CSL_EDMA3_CHA_TCP2REVT;
hChannel1 = CSL_edma3ChannelOpen (&ChObj1, CSL_EDMA3, &chParam1,
&chStatus1);
if ((chStatus1 != CSL_SOK) | (hChannel1 == NULL)) {
printf("Error in EDMA channel open function\n");
return 0;
}
/* Channel Setup */
if (CSL_SOK != CSL_edma3HwChannelSetupParam(hChannel1, 3 /* PaRAM entry 3*/))
{
printf("Error is EDMA channel setup for channel #30\n");
return 0;
}
if (CSL_SOK != CSL_edma3HwChannelSetupQue(hChannel1, CSL_EDMA3_QUE_0))
{
printf("Error is EDMA channel setup for channel #30\n");
return 0;
}
/* Channel Setup */
/* configure param entry 3 to read the hard decisions */
hParam[3] = CSL_edma3GetParamHandle (hChannel1, 3, &chStatus);
myParamSetup.option = CSL_EDMA3_OPT_MAKE (FALSE, FALSE, FALSE, FALSE, 0,
CSL_EDMA3_TCC_NORMAL,
CSL_EDMA3_FIFOWIDTH_NONE,
FALSE,CSL_EDMA3_SYNC_A,
CSL_EDMA3_ADDRMODE_INCR,
CSL_EDMA3_ADDRMODE_INCR);
myParamSetup.srcAddr = (Uint32)CSL_TCP2_O0_MEM;
myParamSetup.aCntbCnt = CSL_EDMA3_CNT_MAKE (8, 1); /* number of bytes of
hard decision data to be read */
myParamSetup.dstAddr = (Uint32)hdDecisionBuffer;
myParamSetup.srcDstBidx = CSL_EDMA3_BIDX_MAKE (1, 1);
myParamSetup.linkBcntrld = CSL_EDMA3_LINKBCNTRLD_MAKE (
CSL_EDMA3_LINK_NULL, 0);
myParamSetup.srcDstCidx = CSL_EDMA3_CIDX_MAKE (1, 1);
myParamSetup.cCnt = 1;
if (CSL_SOK != CSL_edma3ParamSetup (hParam[3], &myParamSetup)) {
printf("Error in EDMA PARAM setup for entry #3\n");
return 0;
}
return 1;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -