OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 3937|回复: 0

一次DMA中断服务函数进入不了问题的排查

[复制链接]

3

主题

7

帖子

0

精华

初级会员

Rank: 2

积分
74
金钱
74
注册时间
2016-9-23
在线时间
21 小时
发表于 2016-9-23 16:21:54 | 显示全部楼层 |阅读模式
     一次进入不了DMA中断服务函数问题的排查,主要原因是在中断服务函数里面使用了printf函数。详细情况是:我用独立模式分别运行ADC2和ADC3,并在他们的DMA传输中断函数里面编写算法。ADC2的采样和DMA传输和中断的处理均正常,但测试ADC3的DMA中断处理时一直在串口显示不出来值,检查了中断服务函数的名称跟.s文件里的中断函数名称是一致的。加上之前ADC2的DMA传输验证正常,就一点一点核对,发现配置也没有问题,但就是进入不了中断服务函数。排查了好几天,发现问题出在中断服务函数里面了,为了省事儿直接在中断服务函数里面使用了printf函数来在串口输出值,猜测是printf函数占用时间较长,而DMA两次中断时间极短(我只传输16个数据),所以DMA中断“卡住了”。于是将printf函数放回在main函数里面,然后,今天天气好晴朗,处处好风光,好风光……,精力都放在检查前面配置上面去了,没想到问题出在这儿,真是蠢得想一头撞死,希望有初学者避开这个弯路,分享给大家。好了,我撞墙去了…

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-22 10:06

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表