11160|7

411

帖子

9

TA的资源

一粒金砂(高级)

楼主
 

stm32f4的DMA1跟DMA2可以同时传输数据么 [复制链接]

进行串口的DMA传输时,stm32f4的DMA1跟DMA2可以同时传输数据么?比如DMA2中的usart1对应数据流跟通道开启,DMA1中的usart2对应的数据流跟通道开启,这时usart1跟usart2可以同时传输数据么?二者有优先级之分么?两个DMA可以同时开启么?
此帖出自stm32/stm8论坛

最新回复

楼上说的是, dma每个通道都有优先级设置  详情 回复 发表于 2019-5-8 20:29
点赞 关注(1)
 

回复
举报

9790

帖子

24

TA的资源

版主

沙发
 
关注一下 期待大神回复
此帖出自stm32/stm8论坛
 
 

回复

1377

帖子

2

TA的资源

五彩晶圆(初级)

板凳
 
“同时” 是指的同时访问总线?
DMA1,  DMA2 都是总线master, Cortex-m4也是总线master. 它们对总线的访问是由仲裁器管理的。不过STM32F4有 bus-matrix 这个结构,也就是多条总线存在,如下面这个图示意的:

只要两个master 访问的 slave 没有交叉,那么访问就可以并行——在同一个时钟周期同时实现访问。 比如这个图上,DMA1 读 AHB1 的设备,DMA2 写 AHB2 的设备,CPU在读 Flash, 那么这三个操作可以同时进行。但是有交叉就不可以,例如 DMA1 和 DMA2 同时读 AHB1 上的不同设备就有冲突,其中一个就必须要等一下。
USART是 APB 上的设备,APB1 和 APB2 通常是接在 AHB1 上的,因此两个 DMA 同时访问 APB1/APB2 是不可以的。
实际上 DMA 访问外设和访问内存是交替进行的,一块SRAM在一个时刻也只能被一个master访问。如果传输数据率高得要考虑DMA瓶颈的时候,SRAM的访问冲突也要一并考虑。
此帖出自stm32/stm8论坛
 
 

回复

1377

帖子

2

TA的资源

五彩晶圆(初级)

4
 
DMA同时开启当然没有问题,同一个DMA多个通道同时开启也没有问题。就算有总线争用发生,也只不过其中一个要稍微等待一下罢了。对于USART这样的低速设备,几乎不可能感觉到DMA访问受阻的存在。
此帖出自stm32/stm8论坛
 
 
 

回复

4008

帖子

0

TA的资源

版主

5
 
楼上说的是,
dma每个通道都有优先级设置
此帖出自stm32/stm8论坛
 
 
 

回复

411

帖子

9

TA的资源

一粒金砂(高级)

6
 
cruelfox 发表于 2019-5-8 10:35
“同时” 是指的同时访问总线?
DMA1,  DMA2 都是总线master, Cortex-m4也是总线master. 它们对总线的访问 ...

此帖出自stm32/stm8论坛
 
 
 

回复

411

帖子

9

TA的资源

一粒金砂(高级)

7
 
cruelfox 发表于 2019-5-8 10:39
DMA同时开启当然没有问题,同一个DMA多个通道同时开启也没有问题。就算有总线争用发生,也只不过其中一个要 ...

此帖出自stm32/stm8论坛
 
 
 

回复

411

帖子

9

TA的资源

一粒金砂(高级)

8
 
huo_hu 发表于 2019-5-8 20:29
楼上说的是,
dma每个通道都有优先级设置

此帖出自stm32/stm8论坛
 
 
 

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

查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表