你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

简单了解一下STM32H7的BDMA

[复制链接]
flyingstar 发布时间:2025-3-26 10:08
DMA,大家非常熟悉了,Direct Memory Access,是在嵌入式系统中对数据搬运起到非常大的辅助作用。在STM32H7系列MCU中,ST公司在片上又实现了一个叫BDMA的功能外设。下面让我们简单了一下它的作用。
( L7 c" u: r. @5 s) y
" t+ @# V/ @7 `; Z, BBDMA(Basic direct memory access controller,基本直接存储器访问控制器),相比通用的DMA1和DMA2,BDMA功能稍弱,支持一些基本的DMA功能。BDMA基础知识BDMA的几个关键知识点:
7 I4 ?% @$ L) @' s: r+ X0 H
0 D# M, u: ^" }; N) j1. 1. 由于总线矩阵的存在,各个主控的道路四通八达,从而可以让DMA和CPU同时开工,但是注意一点,如果他们同时访问的同一个外设,会有一点性能影响的。1 [2 Q: V& G2 ^4 n
2. 2. BDMA支持存储器到外设,外设到存储器,存储器到存储器和外设到外设的传输,其中外设到外设的传输,DMA1和DMA2是不支持的,这个模式在低功耗模式下比较有用。
& s6 j+ v3 N4 Q5 s# \  y3. 3. BDMA只有一个AHB总线主控,而DMA1和DMA2是有两个的,可以分别用于源地址和目的地址的传输。* ?: e% Q. |3 B" _
4. 4. 源地址和目的地址的数据宽度可以不同,但是数据地址必须要跟其数据类型对齐。比如源地址是uint32类型的,那么此数组的地址必须4字节对齐。% }- a0 D2 j2 V0 Y4 o" p' ^0 X# U7 e) }
5. 5. BDMA主要有两种模式,一个是Normal正常模式,传输一次后就停止传输;另一种是Circular循环模式,会一直循环的传输下去,即使有DMA中断,传输也是一直在进行的。
" ?* _6 z; z; Y5 o4 |9 F6 \) K; B+ h6. 6. BDMA的通道请求(Channel0 – Channel7)的优先级可编程,分为四级Very high priority,High priority,Medium priority和Low priority。通道的优先级配置相同的情况下,如果同时产生请求,会优先响应编号低的,即Channel0优先响应。, G. m/ r; r7 l/ H! S5 W
( {. x. o- e- |1 J; L
**BDMA传输**8 a% _3 D7 S2 j5 V: U
4 a: x, ]3 b7 U9 f9 P$ h  c+ F0 M
BDMA支持如下几种传输模式:
" S, b% _" y- u" }: s! G& ?$ I& h6 x, l' d+ @3 }
* 1. 存储器到外设。& G' |7 t- S$ {2 W
* 2. 外设到存储器。
7 `) ^4 d% K; L: J0 u9 g4 F* 3. 存储器到存储器。
4 B9 Z' Q9 I/ D* 4. 外设到外设的传输。# {5 H$ ?: z$ _- w% Z" ?3 |
. }- K5 H0 b8 _* O; E
其中外设到外设的传输,DMA1和DMA2是不支持的,这个模式在低功耗模式下比较有用。. s2 z: D$ v( D- C2 N
: ?  [4 B9 T4 s/ u
关于这几种传输方式要注意以下两个问题:. W* L* M/ k2 U. B
$ d* C) K% g+ }2 h7 ]& h6 I( J
* 1. 源地址和目的地址的数据宽度可以不同,但是数据地址必须要跟其数据类型对齐。比如源地址是uint32类型的,那么此数组的地址必须4字节对齐。+ c" k/ t5 O6 t
* 2. BDMA不可以操作TCM区,其它的SRAM区均可操作/ s% ~. E+ X3 s1 }) j# w  L
0 _  Y# q: J* v2 q) w% r- k1 A7 i
**BDMA的循环模式和正常模式**& w# }) P% r& Z$ l$ l- ]
. W$ L( s6 C' o# G8 p
BDMA主要有两种模式,一个是Normal正常模式,传输一次后就停止传输;另一种是Circular循环模式,会一直循环的传输下去,即使有DMA中断,传输也是一直在进行的。这两种模式各有用途。
) ]7 l% R9 V% E
9 j) R$ G+ w) |+ u* 1. Normal正常模式,适合用于单次传输,比如存储器到存储器的数据复制粘贴,又比如串口的数据单次发送,下次还需要发送的时候,使能下即可。
, ^& P; V. U( D: H& X$ {  I9 j3 W* 2. Circular循环模式,适合用于需要连续传输的场合,比如定时器触发BDMA实现任意IO的PWM输出。( c/ b( Y' O# F

8 \! e# K1 \  q5 w/ `BDMA双缓冲BDMA也是支持双缓冲模式的,双缓冲的含义是源地址或者目的地址可以设置两个缓冲区,这种方式的好处是一个缓冲区在接收或者发送数据的时候,另一个缓冲区可以动态更新数据或者处理已经接收到的数据。当用户开启了BDMA传输完成中断后,通过寄存器CCRx的CT位判断当前使用的是哪个缓冲区
9 S/ L% \" k4 {. D: Q2 Y2 a' G
* 1. 如果CT = 1表示当前正在使用缓冲区1,即寄存器BDMA_CM1ARx记录的地址。
* c( ^# }" s$ x' B, S6 s3 O; u3 N* 2. 如果CT = 0表示当前正在使用缓冲区0,即寄存器BDMA_CM0ARx记录的地址。( [& E3 {, T6 q; m

- e1 j9 a! K9 A" i* X另外注意,存储器到存储器的BDMA传输不支持双缓冲模式,仅可以用于存储器到外设或者外设到存储器。
! c6 }% g; \( L, ^5 ~1 `; u
收藏 评论0 发布时间:2025-3-26 10:08

举报

0个回答

所属标签

相似分享

官网相关资源

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版