完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
电子发烧友论坛|
大家好,我想在IPNC_RDK3.0的alg_link中添加自己的算法,由于实时性的要求,算法中涉及到的很多数据搬移需要EDMA来实现,比如DDR到L2 cache的数据搬移。我试过利用memcpy()来实现,但效率实在太低,无法满足实时性的要求。于是我查阅了关于8127的代码,
1.在sw_osd_ti_dmaOpt.c和sw_osd_ti_dma.c中涉及到了DMA的相关设置,但所有的API都是需要传递一个handle进去,而且所有的API都以SWOSD开头,但我不清楚这个handle需要怎么初始化,如何用在我的算法中。 2,在...ipnc_rdkipnc_mcfwmcfwsrc_bios6links_c6xdspvavalink_alg.c中的VaLink_algCopyFrames()中调用了EDMA.其中有 /* copy the frame */ edmaWidth = pObj->inQueInfo.chInfo[0].width; edmaHeight = pObj->inQueInfo.chInfo[0].height; /* copy Y plane */ DM81XX_EDMA3_setParams(VA_LINK_EDMA3_CH_ID, // chId VA_LINK_EDMA3_QUEUE_ID, // dmaQueue (UInt32)pFullFrame->addr[0][0], // srcAddr (UInt32)pEmptyFrame->addr[0][0], // dstAddr edmaWidth, // edmaWidth edmaHeight, // edmaHeight edmaWidth, // srcLineOffset edmaWidth); // dstLineOffset /* Trigger the edma transfer */ DM81XX_EDMA3_triggerTransfer(VA_LINK_EDMA3_CH_ID); pEmptyFrame->timeStamp = pFullFrame->timeStamp; 于是我将该段代码添加到了Alglink_priv.c中 Int32 AlgLink_algProcessData(AlgLink_Obj * pObj) [ extern unsigned char *frame_buffer; //frame_buffer大小为2048*1280;开辟在在DDR 的SR2上 unsigned char * current_frame; unsigned char * temp; int edmaWidth = 2048; int edmaHeight = 1280; UInt32 frameId, status; System_LinkInQueParams *pInQueParams; FVID2_Frame *pFrame; FVID2_FrameList frameList; pInQueParams = &pObj->createArgs.inQueParams; System_getLinksFullFrames(pInQueParams->prevLinkId, pInQueParams->prevLinkQueId, &frameList); if (frameList.numFrames) [ /* SCD should be done first as it requires to operate on raw YUV */ if (pObj->createArgs.enableSCDAlg) [ status = AlgLink_ScdalgProcessData(&pObj->scdAlg, &frameList, &pObj->outObj[0].bufOutQue); if (status == FVID2_SOK) [ /* Send-out the output bitbuffer */ System_sendLinkCmd(pObj->createArgs.outQueParams.nextLink, SYSTEM_CMD_NEW_DATA); ] ] for(frameId=0; frameId if(pFrame->channelNum >= pObj->inQueInfo.numCh) continue; //*************************************add my alg ****************************// /* copy the frame */ edmaWidth = pObj->inQueInfo.chInfo[0].width; edmaHeight = pObj->inQueInfo.chInfo[0].height; /* copy Y plane */ DM81XX_EDMA3_setParams(VA_LINK_EDMA3_CH_ID, // chId VA_LINK_EDMA3_QUEUE_ID, // dmaQueue (UInt32)pFrame->addr[0][0], // srcAddr (UInt32)(frame_buffer), // dstAddr edmaWidth, // edmaWidth edmaHeight, // edmaHeight edmaWidth, // srcLineOffset edmaWidth); // dstLineOffset /* Trigger the edma transfer */ DM81XX_EDMA3_triggerTransfer(VA_LINK_EDMA3_CH_ID); pEmptyFrame->timeStamp = pFullFrame->timeStamp; //判断数据搬移是否出错 current_frame = (unsigned char *)pFrame->addr[0][0]; temp = frame_buffer; for(i=0;i<2048*1280;i++)[ if(*temp !=*current_frame) Vps_printf("wrong!!!!!!!"); current_frame++; temp++; ] //********************************************************************************// // do SW OSD if (pObj->createArgs.enableOSDAlg) [ AlgLink_OsdalgProcessFrame(&pObj->osdAlg, pFrame); ] ] System_putLinksEmptyFrames(pInQueParams->prevLinkId, pInQueParams->prevLinkQueId, &frameList); ] return FVID2_SOK; ] 编译通过后发现EDMA源地址和目的地址的元素不一致,帧大小为2048*1280没有错,而且我跑的是fullfeature,valink是没有跑的;请问是我的DMA哪里设置不对吗?有谁在8127上用过EDMA的啊?求各位大神指点,小弟在此谢过了!!! |
|
相关推荐
1 个讨论
|
|
只有小组成员才能发言,加入小组>>
545 浏览 0 评论
1609 浏览 0 评论
2045 浏览 0 评论
为啥BQ7693003DBTR芯片在和BQ769X0盒子通讯时收不到信号?
1507 浏览 0 评论
DSP 28027F 开发板 XDS100v2调试探针诊断日志显示了 Error -150 (SC_ERR_FTDI_FAIL)如何解决
1331 浏览 0 评论
AT32F407在USART2 DMA发送数据时,接包接到了要发送的数据,程序还是处于等待传输完成的标识判断中,为什么?
1756浏览 29评论
2781浏览 23评论
请问下tpa3220实际测试引脚功能和官方资料不符,哪位大佬可以帮忙解答下
1723浏览 20评论
请教下关于TAS5825PEVM评估模块原理图中不太明白的地方,寻求答疑
1634浏览 14评论
两个TMP117传感器一个可以正常读取温度值,一个读取的值一直是0,为什么?
1645浏览 13评论
/9
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-12-1 16:37 , Processed in 0.706484 second(s), Total 68, Slave 51 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191

淘帖
2622