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

基于STM32H7 DMA传输的SPI 应用示例

[复制链接]
oneside 发布时间:2019-12-5 10:45
这里使用stm32h743-Nucleo板做个基于DMA传输的SPI收发应用示例。选择SPI1,MOSI与MISO短接,通过DMA自发自收,分开启Cache和不开启Cache来配置演示,以供参考。
! m& `% ^7 B6 Q* N+ e3 K* A
利用STM32CubeMx进行配置,生成基于ARM MDK环境和Cube库的初始化代码。
0 }  r- o) m# I2 ~2 h+ q
SPI1配置在双工主角色,数据位设置为16位。开启SPI的TX/RX的DMA请求。

+ H' Q8 ~, u2 A$ S  h
11.png

( Z$ J: H1 ~+ D5 _
完成其它有关时钟、中断配置后,生成初始化代码并建立工程。

6 R3 f, ?6 C, [, f
一、先不打开Cache。【屏蔽掉相关代码语句】
9 d/ u( G# D% ?) f7 w: z- {
22.png

# C+ d4 f* M) o, a  B, y
我在主程序里周期性地修改待发送的数据,并使能SPI及DMA传输进行数据收发。
6 V9 H$ n% ?: f' k" [' A' k
这里定义了两个内存数组用于数据的收发缓冲,分别是:
0 ]8 A; ^% ?  M$ Z8 ?9 \
33.png
. ]+ @" y) J4 F1 I  E, g7 r! n
实验中我只各用到6个数据,并事先初始化。【对于验证而言,初始值是多少不重要】。
5 h1 [" F# J# i. ]  J: Z5 E
添加相关用户代码。这里我没有开启DMA传输相关中断,这点可以根据需要开启。
4 |$ C8 i& z5 g
44.png

  p9 W: ~( U8 U5 F' M
代码整理、调试完毕,看看结果。下面是通过打断点,在两个时刻的两幅截图。【注:接收缓冲区的起始地址为0x24000020,属于AXIM RAM区】。
# w+ m4 O' _) S
55.jpg
8 ~9 {8 [0 I4 a. J
不难看出,收发数据很一致,那我们接下来看看使用Cache的情况。
二、开启Cache时的情况。
8 {. B# x, K( J6 O
66.png
7 g; v( X6 u' H' ~1 w+ m' y
整个工作流程跟上面一样,在主程序里循环地触发SPI的DMA传输。因为开启了Cache,我们要注意数据一致性问题的处理。在主循环的修改发送收据操作后做了Dcache的清除和失效操作。当然,我们也可以开启DMA传输中断,比方在传输完成中断里做Cache相关的数据更新与维护操作。整个用户代码跟上面不开启Cache时几乎一样,就最后多了一句跟Cache相关的代码。

0 W9 n& A3 G  E8 ?
77.jpg
) T6 y/ t+ K( h: E0 R
稍作整理、编译运行,看看结果。同样,下面是通过打断点,在两个时刻的两幅截图。【注:接收缓冲区起始地址是0x24000020,属于AXIM RAM区】。
+ W- x/ g2 `/ Y' L& L& K
88.jpg

) Q) u' j  u# x* A8 ?1 E( @& j$ y/ v
从验证结果可以看出,发送、接收的数据非常地一致。

3 o) N, W, O- ]/ `' i3 c/ r4 z8 M
这里提醒下,如果开启DCache,对于会被Cache的数据缓冲区,其地址以及缓冲区大小须遵循32字节对齐的原则。所以,关于收发缓冲区的定义及初始化,开启Cache时跟不开启Cache稍有点差异。【下面的6代表代码中用到的六个16位半字数据】
) [+ ~+ H7 {1 l" b
99.png

& q5 H2 `9 @/ m# T/ D: E好,整个示例就分享到这里,需要用到的代码都贴出来了。另外,当开启Cache之后,关于数据更新与维护我们也可以通过配置MPU来实现。
  i0 M. p9 P5 [) h" y. x
5 I2 N- y" v# v+ @# \8 V
* x7 h5 H4 `$ `0 o2 r1 A

* c8 u2 a+ D9 Z( z
; i# ?7 ?8 @" g" G6 |' I8 I+ w
收藏 评论0 发布时间:2019-12-5 10:45

举报

0个回答
关于意法半导体
我们是谁
投资者关系
意法半导体可持续发展举措
创新和工艺
招聘信息
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
关注我们
st-img 微信公众号
st-img 手机版