历史上的今天
今天是:2024年10月11日(星期五)
2019年10月11日 | stm32F4-----DMA的FIFO作用和用法
2019-10-11 来源:eefocus
在STM32F4系列中DMA增加了个FIFO;这个FIFO的作用是什么?
当我使能这个FIFO时(DMA_InitStructure.DMA_FIFOMode = DMA_FIFOMode_Enable;),进仿真模式查看接收数组,他只更新16个字节(我在外边发进去20个字节);读取DMA接收数据个数寄存器显示DMA接收到了20个字节,我 第二次发送数据,接收缓冲又只更新了16个字节(包含上一次未更新的字节);当我把FIFO关闭时(DMA_InitStructure.DMA_FIFOMode = DMA_FIFOMode_Disable;),我在外边不论发送多少字节都一次性更新到接收缓冲区中;这个FIFO的作用是什么?应该在何时使用?怎么用?
DMA 无非就是为了加快数据的传输. 多组数据可以用 burst 方式传输. 字节数据在 FIFO 中变换成 WORD 传输, 减少传输次数.
象你的问题在于, FIFO 的深度设定为 16 了, 这样还有四个字节在 FIFO 中, 数据没有丢失除非你在随后涮洗了 FIFO, 会跟后续的数据一起凑成 16 字节再次传输.你可以减少FIFO 的深度, 比如设置成 1/4. 这样每收到4个字节就会传输. 不过没有更小的选项了. 如果还是不能满足你的要求, 那考虑用 DIRECT 模式吧
建议你将传输计数值设置为20,这样当20个数据进入之后,会全部传输到RAM中,如果你设置FIFO 为 DMA_FIFOThreshold_Full 那么,中间会发生2次传输,一次16字节,一次4字节。
如果你设置FIFO 为 DMA_FIFOThreshold_HalfFull 那么,中间会发生3次传输,一次8字节,一次8字节,一次4字节。
史海拾趣
|
我用TINA_TI直流/交流仿真时出现“TINA7仿真出现“Circuit must contain at least one IC”的对话框怎么办?为什么会这样… 查看全部问答> |
|
这个比较器可以代替,模拟比较器。哪天再深入测下。现在先介绍下函数先: 比较器API提供一组函数来处理模拟比较器。比较器可以将一个测试电压和单个外部参考电压、一个公共的单端外部参考电压或一个公共的内部参考电压相比较。比较器可以 ...… 查看全部问答> |
|
博世安防技术现身知名的莫斯科大剧院 慧聪安防网讯 当著名的莫斯科大剧院于2005年至2011年期间进行整修时,博世被指派开发和 安装最先进的安防系统,包括防火、广播、疏散和视频监控技术。新的系统不仅要提供全面的、可 共同操作的网络,而且还 ...… 查看全部问答> |
|
来自TI硅谷实验室的Jeff为您演示 WEBENCH 系统电源架构。这是一个用于热插拔集成和完整的系统级电源设计的工具。 $(\'swf_zkk\').innerHTML=AC_FL_RunContent(\'width\', \'550\', \'height\', \'400\', \'allowNetworking\', \'internal\', \'all ...… 查看全部问答> |
|
本帖最后由 ltbytyn 于 2013-12-27 14:22 编辑 本文中将使用MB85RC64来代指MB85RC64PNF_G_JNERE1。 前段时间申请到了富士通的MB85RC64(FRAM,铁电随机存取存储器)。看资料MB85RC64与传统的24C64(E2PROM)完全兼容(存储空间、封 ...… 查看全部问答> |
|
做了一个简单的麦克风前置放大,用的是分立元件三极管,第一级共射放大,第二级共集,咪头拾取到的输入信号与经三极管放大后的输出信号电压相位是相反的,相差180度,这样出来的声音和原始声音会不会差别很大。 … 查看全部问答> |
|
最近在用TI的CC2650做一款低功耗蓝牙设备,板子入手两天,发现了一些使用中常遇到的问题,为避免大家走弯路,整理上来,以供参考。 1:开发环境我用的IAR 7.4,SDK版本tirtos_simplelink_2_11_01_09,ble_cc26xx_2_00_00_42893。 建议在完全理解开 ...… 查看全部问答> |




