OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 2829|回复: 9

stm32 CPU与DMA控制器同时访问内存会出现什么情况

[复制链接]

61

主题

160

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
269
金钱
269
注册时间
2012-1-12
在线时间
92 小时
发表于 2018-5-3 08:31:18 | 显示全部楼层 |阅读模式
10金钱
前几天一直在优化程序,原来程序里面有5个通道ADC采集,没有用DMA,昨天我改了程序用DMA ADC来循环采集放到一个二维数组里面(没有开DMA中断)。CPU想用的时候,从这个数组里面取数据就可以了。虽然说改成功了。但是现在有点小疑问,如果DMA正在往这个二维数组里面传数据的时候,CPU也正好想要从这个二维数组里面取数据。这个时候就相当于CPU和DMA同时访问一个内存空间,这个时候会发生什么?原子哥和各位大侠 我在等你们回答。最好回答有根据。谢谢

最佳答案

查看完整内容[请看2#楼]

有总线仲裁啊。会降低传输速率,但是能保证不出问题
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

4

主题

346

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3657
金钱
3657
注册时间
2016-2-21
在线时间
542 小时
发表于 2018-5-3 08:31:19 | 显示全部楼层
有总线仲裁啊。会降低传输速率,但是能保证不出问题
回复

使用道具 举报

19

主题

246

帖子

0

精华

高级会员

Rank: 4

积分
608
金钱
608
注册时间
2017-9-21
在线时间
171 小时
发表于 2018-5-3 08:38:53 | 显示全部楼层
如果不是一直开启的DMA,我都是等待DMA传输完成再去读取数据
回复

使用道具 举报

61

主题

160

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
269
金钱
269
注册时间
2012-1-12
在线时间
92 小时
 楼主| 发表于 2018-5-3 08:41:04 | 显示全部楼层
哆啦A萌 发表于 2018-5-3 08:38
如果不是一直开启的DMA,我都是等待DMA传输完成再去读取数据

DMA一直开启 循环采集ADC的5个通道放入一个二维数组中
回复

使用道具 举报

7

主题

199

帖子

0

精华

高级会员

Rank: 4

积分
711
金钱
711
注册时间
2017-5-20
在线时间
96 小时
发表于 2018-5-3 08:48:52 | 显示全部楼层
不会。你是怎么理解DMA的
DMA传输前,CPU要把总线控制权交给DMA控制器,而在结束DMA传输后,DMA控制器应立即把总线控制权再交回给CPU。
不会出现你说的情况
回复

使用道具 举报

61

主题

160

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
269
金钱
269
注册时间
2012-1-12
在线时间
92 小时
 楼主| 发表于 2018-5-3 08:52:44 | 显示全部楼层
林光华ing 发表于 2018-5-3 08:48
不会。你是怎么理解DMA的
DMA传输前,CPU要把总线控制权交给DMA控制器,而在结束DMA传输后,DMA控制器应立 ...

这样的话问题就来了,当cpu把总线控制权交给DMA的时候,CPU是在等待中的,这样是不是CPU好浪费时间
回复

使用道具 举报

33

主题

215

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2035
金钱
2035
注册时间
2017-12-11
在线时间
454 小时
发表于 2018-5-3 08:59:38 | 显示全部楼层
不会的,原因如下:
sram是直接连接到总线矩阵上的。
dma是通过ahb总线连接到总线矩阵上的。
以下是中文手册原话,也就是说,总线矩阵负责仲裁。
“总线矩阵协调内核系统总线和DMA主控总线之间的访问仲裁,仲裁利用轮换算法。”


回复

使用道具 举报

4

主题

346

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3657
金钱
3657
注册时间
2016-2-21
在线时间
542 小时
发表于 2018-5-3 09:06:01 | 显示全部楼层
谁先抢到谁先用
回复

使用道具 举报

61

主题

160

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
269
金钱
269
注册时间
2012-1-12
在线时间
92 小时
 楼主| 发表于 2018-5-3 09:15:05 | 显示全部楼层
刚才我也看了中文手册,敢肯定的是cpu和DMA不可能以原来的速度同时访问内存的,更不要说访问同一个内存地址了。顶多也就是遇到CPU和dma同时访问内存的话,两个分带宽,这样速度就会降低
回复

使用道具 举报

17

主题

56

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
394
金钱
394
注册时间
2015-1-7
在线时间
101 小时
发表于 2018-5-3 09:24:59 | 显示全部楼层
首先SRAM只有一个接口,总线应该是谁先抢到谁先用,不会同时访问。其次,如果是DMA循环采集,我建议将数组分为两部分,DMA完成一半时产生中断,CPU读取这一半的数据,同时DMA会继续采集后一半的数据,完成后产生中断,CPU再读取后一半的数据,DMA同时开始下一个循环,这样保证读取的数据不会出错。
回复

使用道具 举报

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

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-7 16:24

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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