完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
本帖最后由 一只耳朵怪 于 2018-6-25 11:10 编辑
各位6678的专家们好: 最近在调试EDMA相关的程序时,在查询它的IPR寄存器的时候遇到下面一个问题,还请专家们指教。我在代码中定义了下面的寄存器 #define CHIP_LEVEL_REG 0x02620000 #define KICK0 *(unsigned int*)(CHIP_LEVEL_REG + 0x0038) #define KICK1 *(unsigned int*)(CHIP_LEVEL_REG + 0x003C) #define KICK0_UNLOCK (0x83E70B13) #define KICK1_UNLOCK (0x95A4F1E0) #define KICK_LOCK 0 #define E0IPR *(unsigned int*)(0x02701068) //用于查询传输是否完成 CC0 Global的IPR #define E0ICR *(unsigned int*)(0x02701070) //用于清除相应位 CC0 Global的ICR 加入某个EDMA的传输完成码TCC设为2,我在程序轮询该EDMA是否完成时使用的是下面的语句 while((E0IPR>>1)&0x1 != 1) [ (" nop "); ] 但是在单步调试的时候却发现,这段代码并没有起作用,就是说即便此时IPR的值不为2,单步调试时也没有进入nop等待。想请教各位专家,该如何直接对IPR寄存器进行操作从而查询EDMA传输是否完成呢? 谢谢!!! |
|
相关推荐
2个回答
|
|
将IPR寄存器定义为volatile unsigned int *试试看,还有一个建议就是可以用相关的CSL获取EDMA instance寄存器地址,然后可以用CSL进行配置查询。
|
|
|
|
zbb9612 发表于 2018-6-25 01:04 Andy 你好: 我将寄存器的变量类型修改后还是不起作用,但是后来查询IPR的值我改用了 do [ CSL_edma3GetHwStatus(hModule_Core0,CSL_EDMA3_QUERY_INTRPEND,®ionIntr_Core0); ] while (!(regionIntr_Core0.intr & 0x2)); 然后清除相应位则还是用KICK寄存器组,这样可以满足我的需求 谢谢Andy! |
|
|
|
只有小组成员才能发言,加入小组>>
TMS320F28377D:新做了以377d为芯片的板子,上电后芯片复位引脚出现方波请问如何解决?
1888 浏览 0 评论
TPS55340通电后输入端保险丝烧断,芯片输入和GND之间短路
3645 浏览 4 评论
5031 浏览 0 评论
请问如何用DM368对RGB格式的图片数据进行编码生成JPEG格式图片?
1734 浏览 1 评论
9368 浏览 8 评论
CC3100BOOST使用CC3200lunchXL进行烧录
664浏览 2评论
707浏览 1评论
TMS320F28034: 利用C2prog通过SCI给TMS320F28034烧录程序,出现错误提示:Bootloading... failed (invalid echo)!
668浏览 1评论
求DLPC350 Programmer’s Guide User's Guide 中文版说明书
1197浏览 1评论
1761浏览 1评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-4-23 21:37 , Processed in 0.648989 second(s), Total 77, Slave 60 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号