DMA数据传输的时候,CPU可以同时并行处理其它任务吗?

2019-12-15 11:16发布

000.PNG (23.71 KB, 下载次数: 0) 下载附件 2018-11-24 13:02 上传

想请教下各位:

问题1:上述说法是正确的嘛?还是说每种类型的单片机在DMA这块机制不一样?

问题2:如果上述说法正确的,为什么在进行DMA传输的这段时间内需要挂起CPU?这样使用DMA有什么意义?

问题3:如果上述说法不正确,那么是否会产生资源共享的问题(在DMA传输的这段时间内,DMA也可以看作某种意义上的CPU,与真正的CPU进行资源竞争)?
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
12条回答
20061002838
2019-12-15 22:42
1,正确,对于MSP430单片机而言。不同单片机机制确实不一样,MSP430出于低功耗设计考虑是这样子的,STM32的就不是,DMA传输时CPU可以正常工作
2,430只有一条总线,取指令、取数据、访问RAM、DMA读写都是在这一条总线上面做的,总线带宽不够,所以DMA传输时CPU会被挂起
     依然非常有意义,举个例子,ADC转换完成了需要把结果存入RAM中(或者串口收发数据,等等),如果用CPU来做,需要保护现场、跳转到中断程序、CPU搬运数据、跳转恢复现场,这些事情所消耗的时间远远长于用DMA方式CPU被挂起那段时间
     当然,你如果是每得到一个数据都需要做运算处理,上面的当我没说
3,出问题产生冲突无非就是,DMA和CPU同时写RAM;或者某些寄存器是读清零类型的,先读取的得到了正确的数据,而后读取的得到错误的数据
    430和STM32这种比较简单的,没听说过有这方面的问题,而且上述现象在程序设计的时候很容易避免,缓存ADC结果的内存CPU没事儿写它做什么
    复杂的,有Cache的CPU,会存在这方面的问题,论坛里面有帖子讨论

一周热门 更多>