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

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

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

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

我在这里就这两天调试STM32H750的bootloader和写片内flash的经历分享下自己遇到的问题与解决办法。
+ k+ B! j' r. R9 t一. bootloader地址设置和cache使能失能设置与成功跳转到app的关系7 [% [$ f+ O9 |, Q5 {) Q

/ C; o0 e* ?3 ~8 n
( D/ b% J2 w- x9 r7 ?      1. 首先说明下我bootloader和app部分的flash和SRAM的分配:( e! Q1 d) Y8 d
, d; o. _0 H/ q# M
      因为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。
- e& C2 {# o! r$ Y+ V' ^" A9 \: P! s      然后贴上我bootloader工程中Target的设置:
* L) }# c/ u* T. h" b& ]* A( ]' R; ^9 G9 p
b1.jpg b2.jpg b3.jpg " N, L* [, z) O0 W* R7 [8 V% l7 c7 j# o
7 b5 M1 _# o& y# u
      下面是app中Target的设置:3 @+ R# e, e# C1 }  V6 `0 ^3 N  i
a1.jpg a2.jpg a3.jpg , l2 {! q4 t) p* M" L/ P) j
" l/ a" C; N. ^$ g
      2. cache的设置与地址跳转) l- G) j- q8 k; k+ c# ?2 B
      从上面几张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 Q3 g8 E+ O1 c6 t0 l/ P" V$ A9 V      所以之后有小伙伴涉及到相关问题希望这部分对你有帮助。. E# H0 A0 \4 X2 u3 G
+ z3 |* u' K( [' [2 ~/ v# |
二. STM32H750片内flash操作
: ^% C, ~8 N/ u+ V8 f! w2 x9 X      其实H7与之前的芯片在片内flash上不同的地方就是,写操作必须要按32bytes对齐。意思是即便你只想往里面写一个字节或者不到32个字节,但是flash依然会操作32个字节,只是其中只有一个字节或者你写进去的那么多个字节有效,而其他的字节被mcu自己操作填充,而要这样做就必须操作flash的force-write功能,按照我的经验的话,就是在写之前加一句FLASH->CR1 &= ~FLASH_CR_FW,然后再执行写操作,之后添加一句FLASH->CR1 |= FLASH_CR_FW,即:
6 b& M7 G! U) UFLASH->CR1 &= ~FLASH_CR_FW;3 @# C7 G/ W2 T7 X
HAL_Flash_Program();
4 h/ `: C/ R7 a4 ?9 VFLASH->CR1 |= FLASH_CR_FW
% j1 K, u& B( o; g这样才能保证不会出错(仅我个人调试结果是这样)。
# A- Z  X& B+ n7 c3 ~( n" z所以如果是有连续的数据(大于32bytes),可以先存32bytes然后执行一次写操作,不必去操作force-write功能;如果只是想单独写几个字节可以向我说的这样操作。- j. r/ Y, m* q( m0 T- C

2 X7 B+ U4 F. n1 L/ R2 F附加一点:因为我中间还有调试can通信,而HAL中CAN_TxHeader/CAN_RxHeader里面的DataLength是32bits的,而使用Classic CAN的话,发送和接收的真实数据帧长度最大只有8,会保存在DataLength的高16位,所以如果使用的是Classic CAN接收的话,获取帧长度的时候要将DataLength右移16bits,不然绝对出错。
6 I& Z* n! S& @2 T( D- c; E( ]
" r1 o* V/ f! K$ L9 j, x; W
- |) Q2 d7 L$ P# \1 d3 E! h8 Q
" z% d2 A' a) i! c8 ]7 B: K5 M' {3 D, \0 J& q7 g
- r: ^8 D3 c. g: _; |
收藏 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
2 l4 M. p/ G( xH750不是只有一个sector吗?如果要擦除flash就只能整个sector擦除了,按照你的做法,boot和app都做到128k上 ...

0 }! t* Y% }! k刚才看了一下  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 手机版