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

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

posted @ 2016-09-23 16:29  猪哥杰夫  阅读(2510)  评论(0编辑  收藏  举报