完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
本帖最后由 一只耳朵怪 于 2018-6-19 14:43 编辑
如果是手动触发的话,单核能否开启两个channel进行传输?我现在情况是按照例程定义了两个channel,分别映射不同的param,不同的TCC,但是当我第一次手动触发的时候,设置的传递参数是channe1,可是触发完成后发现,中断完成位确是对应的channel2的TCC。后来我发现无论我输入的是channel1 还是channel2,触发的都是channel2 param所对应的传输。。。 |
|
相关推荐
5个回答
|
|
if (CSL_edma3Init(&context) != CSL_SOK)
[ printf ("Error: EDMA module initialization failedn"); ] hModule = CSL_edma3Open(&edmaObj, INSTNUM, NULL, &status); if ( (hModule == NULL) || (status != CSL_SOK)) [ printf ("Error: EDMA module open failedn"); ] chAttr.regionNum = CSL_EDMA3_REGION_GLOBAL; /*GLOBAL*/ chAttr.chaNum= 0; hChannel1 = CSL_edma3ChannelOpen(&chObj, INSTNUM, &chAttr, &status); if ((hChannel1 == NULL) || (status != CSL_SOK)) [ printf ("Error: Unable to open EDMA Channel:%dn", 0); ] chAttr.chaNum= 1; hChannel2 = CSL_edma3ChannelOpen(&chObj, INSTNUM, &chAttr, &status); if ((hChannel2 == NULL) || (status != CSL_SOK)) [ printf ("Error: Unable to open EDMA Channel:%dn", 1); ] if (CSL_edma3HwChannelSetupQue(hChannel1,CSL_EDMA3_QUE_0) != CSL_SOK) [ printf ("Error: EDMA channel setup queue failedn"); ] if (CSL_edma3HwChannelSetupQue(hChannel2,CSL_EDMA3_QUE_0) != CSL_SOK) [ printf ("Error: EDMA channel setup queue failedn"); ] CSL_edma3MapDMAChannelToParamBlock (hModule, 0, 0); CSL_edma3MapDMAChannelToParamBlock (hModule, 1, 1); Param0= CSL_edma3GetParamHandle(hChannel1, 0, &status); if (Param0 == NULL) [ printf ("Error: EDMA Get Parameter Entry failed for paramID.n"); ] Param1= CSL_edma3GetParamHandle(hChannel2, 1, &status); if (Param1 == NULL) [ printf ("Error: EDMA Get Parameter Entry failed for paramID.n"); ] myParamSetup.option = CSL_EDMA3_OPT_MAKE(CSL_EDMA3_ITCCH_DIS, CSL_EDMA3_TCCH_DIS, CSL_EDMA3_ITCINT_DIS, CSL_EDMA3_TCINT_EN, 0, CSL_EDMA3_TCC_NORMAL, CSL_EDMA3_FIFOWIDTH_NONE, CSL_EDMA3_STATIC_DIS, CSL_EDMA3_SYNC_AB, CSL_EDMA3_ADDRMODE_INCR, CSL_EDMA3_ADDRMODE_INCR ); myParamSetup.srcAddr = (Uint32)DDR;//源地址 myParamSetup.aCntbCnt = CSL_EDMA3_CNT_MAKE(4,512);//因为传输的是Uint32,所以每次array跳变是4byte,一共跳变512 myParamSetup.dstAddr = (Uint32)mem;//目的地址,L2地址必须用全局地址 myParamSetup.srcDstBidx = CSL_EDMA3_BIDX_MAKE(4,4); myParamSetup.linkBcntrld= CSL_EDMA3_LINKBCNTRLD_MAKE(0xFFFF,0);//无link myParamSetup.srcDstCidx = CSL_EDMA3_CIDX_MAKE(0,1); myParamSetup.cCnt = 1; if(CSL_edma3ParamSetup(Param0,&myParamSetup) != CSL_SOK) [ printf ("Error: EDMA Parameter Entry Setup failedn"); ] myParamSetup.option = CSL_EDMA3_OPT_MAKE(CSL_EDMA3_ITCCH_DIS, CSL_EDMA3_TCCH_DIS, CSL_EDMA3_ITCINT_DIS, CSL_EDMA3_TCINT_EN, 1, CSL_EDMA3_TCC_NORMAL, CSL_EDMA3_FIFOWIDTH_NONE, CSL_EDMA3_STATIC_DIS, CSL_EDMA3_SYNC_AB, CSL_EDMA3_ADDRMODE_INCR, CSL_EDMA3_ADDRMODE_INCR ); myParamSetup.srcAddr = (Uint32)mem;//源地址 myParamSetup.aCntbCnt = CSL_EDMA3_CNT_MAKE(4,512);//因为传输的是Uint32,所以每次array跳变是4byte,一共跳变512 myParamSetup.dstAddr = (Uint32)L2+ (0x10000000);//目的地址,L2地址必须用全局地址 myParamSetup.srcDstBidx = CSL_EDMA3_BIDX_MAKE(4,4); myParamSetup.linkBcntrld= CSL_EDMA3_LINKBCNTRLD_MAKE(0xFFFF,0);//无link myParamSetup.srcDstCidx = CSL_EDMA3_CIDX_MAKE(0,1); myParamSetup.cCnt = 1; if(CSL_edma3ParamSetup(Param1,&myParamSetup) != CSL_SOK) [ printf ("Error: EDMA Parameter Entry Setup failedn"); ] regionIntr.region = CSL_EDMA3_REGION_GLOBAL; regionIntr.intr = 0x0003; //中断使能位必须和所设置的TCC相同 regionIntr.intrh = 0x0000; CSL_edma3HwControl(hModule,CSL_EDMA3_CMD_INTR_ENABLE,®ionIntr); regionIntr.intr = 0x0000; CSL_edma3HwChannelControl(hChannel1,CSL_EDMA3_CMD_CHANNEL_SET,NULL); do [ CSL_edma3GetHwStatus(hModule,CSL_EDMA3_QUERY_INTRPEND,®ionIntr); ] while (!(regionIntr.intr & 0x0001));// CSL_edma3HwControl(hModule,CSL_EDMA3_CMD_INTRPEND_CLEAR,®ionIntr); CSL_edma3HwChannelControl(hChannel1,CSL_EDMA3_CMD_CHANNEL_SET,NULL); do [ CSL_edma3GetHwStatus(hModule,CSL_EDMA3_QUERY_INTRPEND,®ionIntr); ] while (!(regionIntr.intr & 0x0002));// CSL_edma3HwControl(hModule,CSL_EDMA3_CMD_INTRPEND_CLEAR,®ionIntr); |
|
|
|
bisong13 发表于 2018-6-19 03:28 2楼是我的代码 |
|
|
|
|
|
|
|
注意函数CSL_edma3ChannelOpen的内部实现,其返回值为hEdma = (CSL_Edma3ChannelHandle)pEdmaObj;所以按照你的这种配置顺序,每个channel在调用如下函数open channel时,其输入第一个参数必须不一样,否则返回值只会记录最后一个channel的参数,所以你的代码中在后面enable channel时使能的始终是channel2.
CSL_Edma3ChannelHandle CSL_edma3ChannelOpen ( CSL_Edma3ChannelObj* pEdmaObj, CSL_InstNum edmaNum, CSL_Edma3ChannelAttr* pChAttr, CSL_Status* pStatus ) |
|
|
|
zbb9612 发表于 2018-6-19 04:11 感谢!! |
|
|
|
只有小组成员才能发言,加入小组>>
336 浏览 1 评论
529 浏览 2 评论
NA555DR VCC最低电压需要在5V供电,为什么用3.3V供电搭了个单稳态触发器也使用正常?
774 浏览 3 评论
MSP430F249TPMR出现高温存储后失效了的情况,怎么解决?
651 浏览 1 评论
对于多级放大电路板,在PCB布局中,电源摆放的位置应该注意什么?
1130 浏览 1 评论
AT32F407在USART2 DMA发送数据时,接包接到了要发送的数据,程序还是处于等待传输完成的标识判断中,为什么?
56浏览 29评论
128浏览 23评论
请问下tpa3220实际测试引脚功能和官方资料不符,哪位大佬可以帮忙解答下
252浏览 20评论
请教下关于TAS5825PEVM评估模块原理图中不太明白的地方,寻求答疑
201浏览 14评论
两个TMP117传感器一个可以正常读取温度值,一个读取的值一直是0,为什么?
57浏览 13评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-23 00:35 , Processed in 1.135983 second(s), Total 88, Slave 71 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号