专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
STM32
DMA数据传输的时候,CPU可以同时并行处理其它任务吗?
2019-12-15 11:16
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
STM32/STM8
4708
12
13
000.PNG
(23.71 KB, 下载次数: 0)
下载附件
2018-11-24 13:02 上传
想请教下各位:
问题1:上述说法是正确的嘛?还是说每种类型的单片机在DMA这块机制不一样?
问题2:如果上述说法正确的,为什么在进行DMA传输的这段时间内需要挂起CPU?这样使用DMA有什么意义?
问题3:如果上述说法不正确,那么是否会产生资源共享的问题(在DMA传输的这段时间内,DMA也可以看作某种意义上的CPU,与真正的CPU进行资源竞争)?
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
12条回答
wx85105157
1楼-- · 2019-12-15 11:43
精彩回答 2 元偷偷看……
加载中...
aozima
2楼-- · 2019-12-15 17:00
CPU的指令中不是所有的指令都在访问总线,所以DMA可以在非数据访问时占用。
DMA也不是一直在访问总线,比如UART速度慢,DMA只有收到触发信号时才传输一个字节。
即使两边碰撞了,还有总线仲裁,会把其中一个暂停一下。
这个暂停的代价比CPU产生中断执行一个ISR小几百倍。
另外总线上面还分不同的BANK,这样CPU和DMA同时访问不同的区域时也不会冲突。
对普通用户来说,可以简单理解为并行就可以了。
如果带宽要上几十MB以上才考虑这块这块的效率。
加载中...
huangqi412
3楼-- · 2019-12-15 21:43
一加一小于二 但是接近二 不同芯片接近程度不同
加载中...
20061002838
4楼-- · 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,会存在这方面的问题,论坛里面有帖子讨论
加载中...
XA144F
5楼-- · 2019-12-16 01:06
在8086时代,DMA还用的是8237,当DMA开始传输数据时,会完全占用地址、数据和控制总线,而CPU在此时使用总线的话会造成各种严重后果。所以8237在开始运行时会发出一个LOCK信号来让8086暂时停止运行,直到8237传输结束后才撤销LOCK信号让8086继续跑。
MSP430估计也是这种情况。
当然,现在的CPU内部带指令缓存和数据缓存,所以就算DMA占用了外部的三总线,CPU还能继续运行,当然在遇到需要从外部存储器中读取D和I时就要耐心等等了。
stm32单片机的DMA是有仲裁的,保证CPU和DMA都能运行而且性能损失最低。就算到了极端情况,仲裁器也能保证CPU有一半的带宽可用。
加载中...
love_ourdev
6楼-- · 2019-12-16 01:41
精彩回答 2 元偷偷看……
加载中...
1
2
下一页
一周热门
更多
>
相关问题
STM32F4上I2C(在PROTEUS中模拟)调试不通的问题
6 个回答
芯片供应紧张,准备换个MCU,MM32L系列替换STM32L系列的怎么样?
7 个回答
STM32同时使用两个串口进行数据收发时数据丢包的问题
5 个回答
STM32F103串口通信死机问题
4 个回答
STM32WLE5CC连接SX1268在LoRa模式下能与 SX1278互通吗?
2 个回答
STM32开发板免费用活动
7 个回答
stm32 处理 DHT11占用太多时间,大家程序是怎么设计的
8 个回答
分享一个STM32单片机做的离线编程器代码
9 个回答
相关文章
ST公司第一款无线低功耗单片机模块有效提高物联网设计生产效率
0个评论
如何实现对单片机寄存器的访问
0个评论
通过USB用STM32片内自带Bootloader下载程序及注意事项
0个评论
欲练此功必先自宫之STM32汇编启动,放慢是为了更好的前行
0个评论
×
关闭
采纳回答
向帮助了您的网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
STM32
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
关闭
您已邀请
15
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
DMA也不是一直在访问总线,比如UART速度慢,DMA只有收到触发信号时才传输一个字节。
即使两边碰撞了,还有总线仲裁,会把其中一个暂停一下。
这个暂停的代价比CPU产生中断执行一个ISR小几百倍。
另外总线上面还分不同的BANK,这样CPU和DMA同时访问不同的区域时也不会冲突。
对普通用户来说,可以简单理解为并行就可以了。
如果带宽要上几十MB以上才考虑这块这块的效率。
2,430只有一条总线,取指令、取数据、访问RAM、DMA读写都是在这一条总线上面做的,总线带宽不够,所以DMA传输时CPU会被挂起
依然非常有意义,举个例子,ADC转换完成了需要把结果存入RAM中(或者串口收发数据,等等),如果用CPU来做,需要保护现场、跳转到中断程序、CPU搬运数据、跳转恢复现场,这些事情所消耗的时间远远长于用DMA方式CPU被挂起那段时间
当然,你如果是每得到一个数据都需要做运算处理,上面的当我没说
3,出问题产生冲突无非就是,DMA和CPU同时写RAM;或者某些寄存器是读清零类型的,先读取的得到了正确的数据,而后读取的得到错误的数据
430和STM32这种比较简单的,没听说过有这方面的问题,而且上述现象在程序设计的时候很容易避免,缓存ADC结果的内存CPU没事儿写它做什么
复杂的,有Cache的CPU,会存在这方面的问题,论坛里面有帖子讨论
MSP430估计也是这种情况。
当然,现在的CPU内部带指令缓存和数据缓存,所以就算DMA占用了外部的三总线,CPU还能继续运行,当然在遇到需要从外部存储器中读取D和I时就要耐心等等了。
stm32单片机的DMA是有仲裁的,保证CPU和DMA都能运行而且性能损失最低。就算到了极端情况,仲裁器也能保证CPU有一半的带宽可用。
一周热门 更多>