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

STM32H750启动代码与片内flash操作小经验分享

[复制链接]
思行一 发布时间:2019-2-22 12:02

首先感谢STM32 FAE的支持,迅速有效,非常感谢!然后也非常感谢论坛里的大佬们的帮助回答!

我在这里就这两天调试STM32H750的bootloader和写片内flash的经历分享下自己遇到的问题与解决办法。+ s& h( W* C6 i6 Y: ]2 F" V
一. bootloader地址设置和cache使能失能设置与成功跳转到app的关系
9 M! Y- i9 v. y& L1 v' ]- r8 i. {; [* ~$ T4 u% T: H

6 `$ Y; N0 T: {0 H6 j2 W      1. 首先说明下我bootloader和app部分的flash和SRAM的分配:
& L# [' ^# V3 d
9 f& W# e; L6 I: g( r      因为STM32H750的片内flash只有128K,地址是从0x0800 0000 ~ 0x0801 FFFF,我的bootloader大小有12k左右,所以我将bootloader存放到flash的前16k,即地址0x0800 0000 ~ 0x0800 5FFF,在SRAM里使用的起始地址0x2000 0000,大小0x20000;剩下的116K用于存放我的app程序,即地址0x0800 6000 ~ 0x0801 FFFF, 在SRAM里使用的起始地址0x2400 0000,大小0x80000。" s' i/ K5 l8 X4 g! j9 G0 }% g
      然后贴上我bootloader工程中Target的设置:
; F; M4 z, N0 _7 C6 x$ m" l0 P4 y6 R
b1.jpg b2.jpg b3.jpg
( Z' n2 q, z, Q5 [. T9 T- ~/ Q- Z6 A% Z. s) O- Q/ I( @+ w* i( X3 W8 [
      下面是app中Target的设置:
5 w+ a& s5 U9 m1 Y4 S& n$ H a1.jpg a2.jpg a3.jpg
7 ?2 P# a( [1 l
0 `! N, `6 C# i, ]      2. cache的设置与地址跳转; T0 C+ {4 C& l' c, _! T5 }
      从上面几张target中的设置可以看到我app部分的RAM是使用的是AXI SRAM,bootloader使用的是TCM SRAM, 而在bootloader中一开始我是使能的D-Cache和I-Cache的,我在写完bootloader后无法跳转到自己的app程序去,检查了自己程序里面地址设置与app中中断向量表也作了对应修改,还是无法跳转过去后,向FAE求助,他们给的办法是在bootloader中,地址跳转前将D-Cache失能,即使用HAL库下的函数:SCB_DisableDCache()。添加此函数后能够成功向app跳转。2 `5 L' Y) U# p0 A" [
      所以之后有小伙伴涉及到相关问题希望这部分对你有帮助。$ `! G2 Q) u9 O

9 @" Y1 v; S0 q5 }二. STM32H750片内flash操作% h8 t- Y. ~% N4 `) }
      其实H7与之前的芯片在片内flash上不同的地方就是,写操作必须要按32bytes对齐。意思是即便你只想往里面写一个字节或者不到32个字节,但是flash依然会操作32个字节,只是其中只有一个字节或者你写进去的那么多个字节有效,而其他的字节被mcu自己操作填充,而要这样做就必须操作flash的force-write功能,按照我的经验的话,就是在写之前加一句FLASH->CR1 &= ~FLASH_CR_FW,然后再执行写操作,之后添加一句FLASH->CR1 |= FLASH_CR_FW,即:
4 n9 |/ J  E6 K' B: a& k* _FLASH->CR1 &= ~FLASH_CR_FW;
7 \6 ^/ R4 X0 y; T  `  o. tHAL_Flash_Program();* p) Z- f* i4 b" {# H6 `5 h
FLASH->CR1 |= FLASH_CR_FW
8 g! A4 Z7 r: s1 y! B* Y! \这样才能保证不会出错(仅我个人调试结果是这样)。
( ]5 I, ^" ]0 y, @所以如果是有连续的数据(大于32bytes),可以先存32bytes然后执行一次写操作,不必去操作force-write功能;如果只是想单独写几个字节可以向我说的这样操作。9 m+ u4 C  J; s( u
# ]) L! c% \2 A; V' L" y8 K
附加一点:因为我中间还有调试can通信,而HAL中CAN_TxHeader/CAN_RxHeader里面的DataLength是32bits的,而使用Classic CAN的话,发送和接收的真实数据帧长度最大只有8,会保存在DataLength的高16位,所以如果使用的是Classic CAN接收的话,获取帧长度的时候要将DataLength右移16bits,不然绝对出错。4 ~* s9 I% p5 {: W; T3 z& G. V$ G

  [4 u9 H" L9 ]8 K: l( ^, i4 c# |

" n% e  G2 N+ B8 U
/ t: P) l; `" ~2 X$ m* P2 r
6 k1 k( `: |1 P! Z$ N! u
收藏 2 评论4 发布时间:2019-2-22 12:02

举报

4个回答
-- 回答时间:2019-4-14 19:11:32
H750不是只有一个sector吗?如果要擦除flash就只能整个sector擦除了,按照你的做法,boot和app都做到128k上,boot根本无法升级app,没有意义啊
wofei1314 回答时间:2019-5-9 13:19:14
gzbkey 发表于 2019-4-14 19:11
, i' N- j/ C- ^0 J' xH750不是只有一个sector吗?如果要擦除flash就只能整个sector擦除了,按照你的做法,boot和app都做到128k上 ...
, ?6 F  t3 R5 l2 D* c
刚才看了一下  RM0433.pdf  ,确实只有1个Sector ....  如果是这样的话,每次IAP 擦除的时候就会把BootLoader 也一并擦除 ....
woods1 回答时间:2019-10-14 16:12:56
外挂FLASH程序怎么操作?
woods1 回答时间:2019-11-4 16:57:34
还以为是QSPI

所属标签

相似分享

官网相关资源

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