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

简单了解一下STM32H7的BDMA

[复制链接]
flyingstar 发布时间:2025-3-26 10:08
DMA,大家非常熟悉了,Direct Memory Access,是在嵌入式系统中对数据搬运起到非常大的辅助作用。在STM32H7系列MCU中,ST公司在片上又实现了一个叫BDMA的功能外设。下面让我们简单了一下它的作用。. T& }4 D1 m, L2 ~9 d) z8 z

+ s% X( n) [! |" j7 k, L* KBDMA(Basic direct memory access controller,基本直接存储器访问控制器),相比通用的DMA1和DMA2,BDMA功能稍弱,支持一些基本的DMA功能。BDMA基础知识BDMA的几个关键知识点:) ~- d0 G5 O- I( W$ d

% s( |. F% z; o! F/ O1. 1. 由于总线矩阵的存在,各个主控的道路四通八达,从而可以让DMA和CPU同时开工,但是注意一点,如果他们同时访问的同一个外设,会有一点性能影响的。$ P' R; Q# y$ p- N6 r4 t
2. 2. BDMA支持存储器到外设,外设到存储器,存储器到存储器和外设到外设的传输,其中外设到外设的传输,DMA1和DMA2是不支持的,这个模式在低功耗模式下比较有用。1 w/ J/ j' p6 B0 C
3. 3. BDMA只有一个AHB总线主控,而DMA1和DMA2是有两个的,可以分别用于源地址和目的地址的传输。; R5 u' S9 F" a
4. 4. 源地址和目的地址的数据宽度可以不同,但是数据地址必须要跟其数据类型对齐。比如源地址是uint32类型的,那么此数组的地址必须4字节对齐。
( F+ b4 N; _8 S5. 5. BDMA主要有两种模式,一个是Normal正常模式,传输一次后就停止传输;另一种是Circular循环模式,会一直循环的传输下去,即使有DMA中断,传输也是一直在进行的。
9 P7 e! f4 @- \8 z" u( U4 N- F6. 6. BDMA的通道请求(Channel0 – Channel7)的优先级可编程,分为四级Very high priority,High priority,Medium priority和Low priority。通道的优先级配置相同的情况下,如果同时产生请求,会优先响应编号低的,即Channel0优先响应。
! E6 m2 p, Y! L7 y& q* F/ \
$ h$ ]" j! D; i2 Z4 Y; S: }/ J3 B**BDMA传输**
) {( W5 j. M& D# x' O1 r; y
+ w; D8 r' o$ JBDMA支持如下几种传输模式:. I- L; I1 i: Y' r; B! l
3 ~+ s+ {3 S7 r; m7 b  E
* 1. 存储器到外设。& K0 V' n& J0 L  `. u0 J
* 2. 外设到存储器。
" m! C3 v* i9 a8 [2 R* 3. 存储器到存储器。
0 b+ q* L) U  x# r$ I2 |, K* 4. 外设到外设的传输。3 F# z1 {  u2 B6 J* x6 e  k

2 l& ]6 h" Z: ~, N9 g! T其中外设到外设的传输,DMA1和DMA2是不支持的,这个模式在低功耗模式下比较有用。
' m6 a8 j: ?% C, y4 {4 f6 m' M* ]& d6 f# t8 p& K. w- @* Y6 ^/ H$ u8 ~. y
关于这几种传输方式要注意以下两个问题:
% \+ K- j$ V8 ?3 z& _3 i$ F& R6 `/ ]8 D- v2 i+ X) ~7 G
* 1. 源地址和目的地址的数据宽度可以不同,但是数据地址必须要跟其数据类型对齐。比如源地址是uint32类型的,那么此数组的地址必须4字节对齐。  T3 L. b+ }) t" I1 k
* 2. BDMA不可以操作TCM区,其它的SRAM区均可操作
$ o, q1 k1 @: N
3 d$ ]4 S% v) @- V9 N5 J1 T**BDMA的循环模式和正常模式**
8 E8 |7 ]+ Z! s; C% e. E7 f6 l7 b$ s: @0 f* V
BDMA主要有两种模式,一个是Normal正常模式,传输一次后就停止传输;另一种是Circular循环模式,会一直循环的传输下去,即使有DMA中断,传输也是一直在进行的。这两种模式各有用途。7 D. V: m/ \( k) s, w) p5 ^
% ^2 k* [8 t+ B- h: w  Q# S0 p, y
* 1. Normal正常模式,适合用于单次传输,比如存储器到存储器的数据复制粘贴,又比如串口的数据单次发送,下次还需要发送的时候,使能下即可。
8 h4 M  a8 e  ^* 2. Circular循环模式,适合用于需要连续传输的场合,比如定时器触发BDMA实现任意IO的PWM输出。
. s2 U9 t1 X$ L- H4 @( v; K
. R% T; u" S/ R* wBDMA双缓冲BDMA也是支持双缓冲模式的,双缓冲的含义是源地址或者目的地址可以设置两个缓冲区,这种方式的好处是一个缓冲区在接收或者发送数据的时候,另一个缓冲区可以动态更新数据或者处理已经接收到的数据。当用户开启了BDMA传输完成中断后,通过寄存器CCRx的CT位判断当前使用的是哪个缓冲区* Q6 J; L2 a5 n3 M8 t! [
, o+ a; U* d; n! i1 o
* 1. 如果CT = 1表示当前正在使用缓冲区1,即寄存器BDMA_CM1ARx记录的地址。0 p: |0 o/ f: g
* 2. 如果CT = 0表示当前正在使用缓冲区0,即寄存器BDMA_CM0ARx记录的地址。
( N+ y' z6 ~1 b
6 \6 p9 P* D5 m3 ^3 A) a另外注意,存储器到存储器的BDMA传输不支持双缓冲模式,仅可以用于存储器到外设或者外设到存储器。* x* y8 P4 a$ a( I6 i
收藏 评论0 发布时间:2025-3-26 10:08

举报

0个回答

所属标签

相似分享

官网相关资源

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