OpenEdv-开源电子网

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

DMA何时启动的问题和双缓冲DMA的问题

[复制链接]

3

主题

7

帖子

0

精华

新手上路

积分
28
金钱
28
注册时间
2016-10-17
在线时间
9 小时
发表于 2016-10-17 20:38:49 | 显示全部楼层 |阅读模式
1金钱
问题1
请问,配置完DMA之后使能真正一次数据传输是以什么方式触发的呢?或者说,DMA的传输速度是怎样的?以F407开发板为例,摄像头数据DCMI采过来,DMA什么时候把这个数据传输到RAM去呢?是每次DCMI数据更新,以此为触发信号启动一次DMA吗?还是以固定的某个时钟进行传输,如果是这样,以慢速外设为源,得到的数据岂不错乱了?

问题2

另外,探索者开发板的照相机例程,对JPEG格式拍照时用到了双缓冲DMA,先把图像数据DMA到片内SRAM双缓冲,在dma中断里把数据搬到片外SRAM,最后将片外SRAM数据保存SD卡文件。视频讲解说用双缓冲的原因是片外SRAM的速度较慢,跟不上DCMI,我的疑问是,在DMA中断里把缓冲区数据搬到片外SRAM的过程同样跟不上DCMI,而且,在DMA中断里搬运数据反而还增加CPU的开销。


最佳答案

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

1,由DCMI驱动。当DCMI_DR寄存器数据准备好之后,就会触发一次DMA请求,传输DR数据到内存。 2,JPEG输出不是持续的,你去看PIXCLK的时钟就知道了。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165377
金钱
165377
注册时间
2010-12-1
在线时间
2111 小时
发表于 2016-10-17 20:38:50 | 显示全部楼层
1,由DCMI驱动。当DCMI_DR寄存器数据准备好之后,就会触发一次DMA请求,传输DR数据到内存。
2,JPEG输出不是持续的,你去看PIXCLK的时钟就知道了。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

3

主题

7

帖子

0

精华

新手上路

积分
28
金钱
28
注册时间
2016-10-17
在线时间
9 小时
 楼主| 发表于 2016-10-19 09:14:49 来自手机 | 显示全部楼层
谢谢原子哥
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-3-1 02:30

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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