完善资料让更多小伙伴认识你,还能领取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! |
|
|
|
|
只有小组成员才能发言,加入小组>>
549 浏览 0 评论
1613 浏览 0 评论
2047 浏览 0 评论
为啥BQ7693003DBTR芯片在和BQ769X0盒子通讯时收不到信号?
1513 浏览 0 评论
DSP 28027F 开发板 XDS100v2调试探针诊断日志显示了 Error -150 (SC_ERR_FTDI_FAIL)如何解决
1337 浏览 0 评论
AT32F407在USART2 DMA发送数据时,接包接到了要发送的数据,程序还是处于等待传输完成的标识判断中,为什么?
1756浏览 29评论
2781浏览 23评论
请问下tpa3220实际测试引脚功能和官方资料不符,哪位大佬可以帮忙解答下
1724浏览 20评论
请教下关于TAS5825PEVM评估模块原理图中不太明白的地方,寻求答疑
1634浏览 14评论
两个TMP117传感器一个可以正常读取温度值,一个读取的值一直是0,为什么?
1645浏览 13评论
/9
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-12-2 02:16 , Processed in 1.865326 second(s), Total 74, Slave 57 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191

淘帖
4655