搜索
bottom↓
回复: 12

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

[复制链接]

出0入0汤圆

发表于 2018-11-24 13:16:03 | 显示全部楼层 |阅读模式


想请教下各位:

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

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

问题3:如果上述说法不正确,那么是否会产生资源共享的问题(在DMA传输的这段时间内,DMA也可以看作某种意义上的CPU,与真正的CPU进行资源竞争)?

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

阿莫论坛20周年了!感谢大家的支持与爱护!!

一只鸟敢站在脆弱的枝条上歇脚,它依仗的不是枝条不会断,而是自己有翅膀,会飞。

出0入0汤圆

发表于 2018-11-24 13:31:07 来自手机 | 显示全部楼层
不一样。stm32f1的dma和cpu有仲裁。cpu有最高优先访问权。然后cpu从flash取指令的时候有缓存的。f3f4是有更多的总线,不用仲裁。而且dma也带缓存了。

出0入0汤圆

发表于 2018-11-24 13:37:42 | 显示全部楼层
CPU的指令中不是所有的指令都在访问总线,所以DMA可以在非数据访问时占用。

DMA也不是一直在访问总线,比如UART速度慢,DMA只有收到触发信号时才传输一个字节。

即使两边碰撞了,还有总线仲裁,会把其中一个暂停一下。
这个暂停的代价比CPU产生中断执行一个ISR小几百倍。

另外总线上面还分不同的BANK,这样CPU和DMA同时访问不同的区域时也不会冲突。

对普通用户来说,可以简单理解为并行就可以了。
如果带宽要上几十MB以上才考虑这块这块的效率。

出0入0汤圆

发表于 2018-11-24 13:43:14 来自手机 | 显示全部楼层
一加一小于二  但是接近二  不同芯片接近程度不同

出0入24汤圆

发表于 2018-11-24 13:49:52 | 显示全部楼层
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,会存在这方面的问题,论坛里面有帖子讨论

出0入0汤圆

发表于 2018-11-24 14:24:19 | 显示全部楼层
在8086时代,DMA还用的是8237,当DMA开始传输数据时,会完全占用地址、数据和控制总线,而CPU在此时使用总线的话会造成各种严重后果。所以8237在开始运行时会发出一个LOCK信号来让8086暂时停止运行,直到8237传输结束后才撤销LOCK信号让8086继续跑。
MSP430估计也是这种情况。
当然,现在的CPU内部带指令缓存和数据缓存,所以就算DMA占用了外部的三总线,CPU还能继续运行,当然在遇到需要从外部存储器中读取D和I时就要耐心等等了。
stm32单片机的DMA是有仲裁的,保证CPU和DMA都能运行而且性能损失最低。就算到了极端情况,仲裁器也能保证CPU有一半的带宽可用。

出870入263汤圆

发表于 2018-11-24 14:45:47 | 显示全部楼层
aozima 发表于 2018-11-24 13:37
CPU的指令中不是所有的指令都在访问总线,所以DMA可以在非数据访问时占用。

DMA也不是一直在访问总线,比 ...

很精辟!多种情况都提到了,+1024

出0入0汤圆

 楼主| 发表于 2018-11-24 14:49:53 | 显示全部楼层
aozima 发表于 2018-11-24 13:37
CPU的指令中不是所有的指令都在访问总线,所以DMA可以在非数据访问时占用。

DMA也不是一直在访问总线,比 ...

感谢aozima阁下指教,我再理解下!

出0入0汤圆

 楼主| 发表于 2018-11-24 14:53:00 | 显示全部楼层
20061002838 发表于 2018-11-24 13:49
1,正确,对于MSP430单片机而言。不同单片机机制确实不一样,MSP430出于低功耗设计考虑是这样子的,STM32的 ...

感谢20061002838阁下指教!

出0入0汤圆

发表于 2018-11-25 17:52:27 | 显示全部楼层
XA144F 发表于 2018-11-24 14:24
在8086时代,DMA还用的是8237,当DMA开始传输数据时,会完全占用地址、数据和控制总线,而CPU在此时使用总 ...

学习了!!

出0入0汤圆

发表于 2018-11-27 12:06:13 | 显示全部楼层
涨了一波姿势

出0入0汤圆

发表于 2018-11-27 12:50:07 | 显示全部楼层
学习了

出10入12汤圆

发表于 2018-11-27 16:19:16 | 显示全部楼层
不错的资料!!!!!!!
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-6-18 00:49

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

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