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

简单了解一下STM32H7的BDMA

[复制链接]
flyingstar 发布时间:2025-3-26 10:08
DMA,大家非常熟悉了,Direct Memory Access,是在嵌入式系统中对数据搬运起到非常大的辅助作用。在STM32H7系列MCU中,ST公司在片上又实现了一个叫BDMA的功能外设。下面让我们简单了一下它的作用。" ~: h0 u- [* {* K+ Z
1 m5 Z8 N! j5 U; U- @, [8 W
BDMA(Basic direct memory access controller,基本直接存储器访问控制器),相比通用的DMA1和DMA2,BDMA功能稍弱,支持一些基本的DMA功能。BDMA基础知识BDMA的几个关键知识点:1 I; ?$ I2 @3 X

% `8 O/ V! [3 e( h' C9 ?1. 1. 由于总线矩阵的存在,各个主控的道路四通八达,从而可以让DMA和CPU同时开工,但是注意一点,如果他们同时访问的同一个外设,会有一点性能影响的。
4 k* u) f6 h& M4 @& U2 R  l2 d2. 2. BDMA支持存储器到外设,外设到存储器,存储器到存储器和外设到外设的传输,其中外设到外设的传输,DMA1和DMA2是不支持的,这个模式在低功耗模式下比较有用。2 ?* X4 F+ u: j' b9 O$ W0 {
3. 3. BDMA只有一个AHB总线主控,而DMA1和DMA2是有两个的,可以分别用于源地址和目的地址的传输。
  N  m5 P* v. {4. 4. 源地址和目的地址的数据宽度可以不同,但是数据地址必须要跟其数据类型对齐。比如源地址是uint32类型的,那么此数组的地址必须4字节对齐。
( H0 G6 L2 c) Q' A0 h0 f) l3 F( U, Y5. 5. BDMA主要有两种模式,一个是Normal正常模式,传输一次后就停止传输;另一种是Circular循环模式,会一直循环的传输下去,即使有DMA中断,传输也是一直在进行的。! ]: b) P& E) i( w
6. 6. BDMA的通道请求(Channel0 – Channel7)的优先级可编程,分为四级Very high priority,High priority,Medium priority和Low priority。通道的优先级配置相同的情况下,如果同时产生请求,会优先响应编号低的,即Channel0优先响应。% `' `0 v, J0 G
# k3 g/ X, B- }2 y8 K
**BDMA传输**
% Y8 I7 ^$ }$ H+ b$ s: x4 O9 L; Y  O8 Y4 P1 j
BDMA支持如下几种传输模式:  _% t( i6 g, N5 N7 Q0 R' h- a

- N  g: n; Y" T8 [1 N1 y* 1. 存储器到外设。
" r8 t! z& Y# `# B! ?# F$ B* 2. 外设到存储器。1 S4 k! m6 u5 C& F
* 3. 存储器到存储器。
9 I3 h$ C* ^- k. M0 s( P2 r" B* 4. 外设到外设的传输。5 u% k) @& P9 N7 Z

  I8 n) _& @3 T3 J/ x8 |其中外设到外设的传输,DMA1和DMA2是不支持的,这个模式在低功耗模式下比较有用。/ K1 z; F7 y9 Y9 z. l
! M4 Q7 ]$ {9 i
关于这几种传输方式要注意以下两个问题:
4 S- F) s- O) a2 |( Z4 [
  x% ^% A# q+ C3 a# i1 e* 1. 源地址和目的地址的数据宽度可以不同,但是数据地址必须要跟其数据类型对齐。比如源地址是uint32类型的,那么此数组的地址必须4字节对齐。6 z) Y8 y3 G& y5 X' y0 v2 Q, G
* 2. BDMA不可以操作TCM区,其它的SRAM区均可操作
* H6 L! R0 [& }4 g
# f0 _3 x+ o6 G. s/ k- V**BDMA的循环模式和正常模式**7 j& p3 i8 U; p, {& U& s  k0 N2 r

9 X4 E+ n$ h7 F; t1 jBDMA主要有两种模式,一个是Normal正常模式,传输一次后就停止传输;另一种是Circular循环模式,会一直循环的传输下去,即使有DMA中断,传输也是一直在进行的。这两种模式各有用途。; W% d; G1 V& G; }
7 _9 G5 P6 Q1 h/ {
* 1. Normal正常模式,适合用于单次传输,比如存储器到存储器的数据复制粘贴,又比如串口的数据单次发送,下次还需要发送的时候,使能下即可。! M, h0 w2 t5 |' D
* 2. Circular循环模式,适合用于需要连续传输的场合,比如定时器触发BDMA实现任意IO的PWM输出。
- _' r4 n2 i9 w' e) D/ l" n. V! A: a6 R- E  U" j
BDMA双缓冲BDMA也是支持双缓冲模式的,双缓冲的含义是源地址或者目的地址可以设置两个缓冲区,这种方式的好处是一个缓冲区在接收或者发送数据的时候,另一个缓冲区可以动态更新数据或者处理已经接收到的数据。当用户开启了BDMA传输完成中断后,通过寄存器CCRx的CT位判断当前使用的是哪个缓冲区
: z- j/ ~3 T. F* }7 ]# a% R* p
* 1. 如果CT = 1表示当前正在使用缓冲区1,即寄存器BDMA_CM1ARx记录的地址。% \! _! c2 [# c$ ~7 o
* 2. 如果CT = 0表示当前正在使用缓冲区0,即寄存器BDMA_CM0ARx记录的地址。5 G" E) U+ x( L6 z
" [! l; N0 Y: }: r
另外注意,存储器到存储器的BDMA传输不支持双缓冲模式,仅可以用于存储器到外设或者外设到存储器。) l/ m* \& S. i4 J
收藏 评论0 发布时间:2025-3-26 10:08

举报

0个回答

所属标签

相似分享

官网相关资源

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