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

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

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

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

我在这里就这两天调试STM32H750的bootloader和写片内flash的经历分享下自己遇到的问题与解决办法。% D7 V" Q9 E1 k  X! r
一. bootloader地址设置和cache使能失能设置与成功跳转到app的关系; n* E" O* s4 l; b) q

8 J7 [7 z* q3 c! g, K" `% R8 Y2 F2 }% \! }) Q& k
      1. 首先说明下我bootloader和app部分的flash和SRAM的分配:5 R! c- U' N  D; B; h

. r! `9 ]9 N5 T% G- ]      因为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。
% d# H% o9 s; T$ ?( G) G& c+ a0 j      然后贴上我bootloader工程中Target的设置:* p) d7 r2 ^" F

" @) G- r% S* u b1.jpg b2.jpg b3.jpg
/ E1 L. X1 N8 z7 t/ @' t& ?
' H$ f. _4 f& _% B) L' V      下面是app中Target的设置:$ g+ Q7 J/ s2 O2 e( C
a1.jpg a2.jpg a3.jpg   z. n* g! R& A% ~! i- e! ]% w

' x& r8 w7 ^1 s1 F8 f( K5 \      2. cache的设置与地址跳转6 k; m  B, [4 p  [
      从上面几张target中的设置可以看到我app部分的RAM是使用的是AXI SRAM,bootloader使用的是TCM SRAM, 而在bootloader中一开始我是使能的D-Cache和I-Cache的,我在写完bootloader后无法跳转到自己的app程序去,检查了自己程序里面地址设置与app中中断向量表也作了对应修改,还是无法跳转过去后,向FAE求助,他们给的办法是在bootloader中,地址跳转前将D-Cache失能,即使用HAL库下的函数:SCB_DisableDCache()。添加此函数后能够成功向app跳转。
  V; B+ ]9 G" ^8 [) b9 C$ b      所以之后有小伙伴涉及到相关问题希望这部分对你有帮助。
* A7 `+ H4 }5 }3 p) r8 Y3 S8 P
8 P1 t! y- N# L" g! ~' x二. STM32H750片内flash操作  o1 ]/ l) K+ U" x. ^/ z
      其实H7与之前的芯片在片内flash上不同的地方就是,写操作必须要按32bytes对齐。意思是即便你只想往里面写一个字节或者不到32个字节,但是flash依然会操作32个字节,只是其中只有一个字节或者你写进去的那么多个字节有效,而其他的字节被mcu自己操作填充,而要这样做就必须操作flash的force-write功能,按照我的经验的话,就是在写之前加一句FLASH->CR1 &= ~FLASH_CR_FW,然后再执行写操作,之后添加一句FLASH->CR1 |= FLASH_CR_FW,即:
( H' t/ ?5 x4 g- @3 t' ~" UFLASH->CR1 &= ~FLASH_CR_FW;. m9 I# v2 d3 @2 \( m8 b% X
HAL_Flash_Program();7 l5 k( }5 v+ u) _% h4 b; W
FLASH->CR1 |= FLASH_CR_FW3 \* L# K4 G( S$ @* J  W( ]3 H
这样才能保证不会出错(仅我个人调试结果是这样)。
5 C9 S/ h; B9 Y( Q所以如果是有连续的数据(大于32bytes),可以先存32bytes然后执行一次写操作,不必去操作force-write功能;如果只是想单独写几个字节可以向我说的这样操作。  O2 _6 \% W8 B4 G4 z; P# H0 F" p
5 `" A" N0 n2 g/ s
附加一点:因为我中间还有调试can通信,而HAL中CAN_TxHeader/CAN_RxHeader里面的DataLength是32bits的,而使用Classic CAN的话,发送和接收的真实数据帧长度最大只有8,会保存在DataLength的高16位,所以如果使用的是Classic CAN接收的话,获取帧长度的时候要将DataLength右移16bits,不然绝对出错。
, x3 n5 F' H+ q- g# @
& a- g# l. K8 H1 Y$ u  {- o6 T/ _

' t3 N2 L- U: t2 D% m  R/ v0 g) b0 b- y1 d3 }, T: Z
+ ^6 i) q0 @) \* _8 J8 d
收藏 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; W! v5 ^, @2 M; G5 @: |1 W# BH750不是只有一个sector吗?如果要擦除flash就只能整个sector擦除了,按照你的做法,boot和app都做到128k上 ...

" g1 C' i# y% v2 v3 n, x0 ]* Z& x* J: B刚才看了一下  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 手机版