电子产业一站式赋能平台

PCB联盟网

搜索
查看: 192|回复: 0
收起左侧

MCU固件升级Flash划分方式

[复制链接]

461

主题

461

帖子

5053

积分

四级会员

Rank: 4

积分
5053
发表于 2024-11-1 11:46:00 | 显示全部楼层 |阅读模式
关注+星标公众,不错过精彩内容

w1rzy5nqmkm64078309240.jpg

w1rzy5nqmkm64078309240.jpg

素材来源 | 网络
之前给大家分享过《MCU批量生产下载程序的几种常见方法》,今天再给大家分享一下通过OTA方式升级固件时,几种Flash(闪存)划分方式。
独立型
所谓独立型就是专门划出一部分闪存(Flash)空间用来存储引导程序(BootLoader)。
如下图:
  • BootLoader:引导程序
  • Firmware A:应用程序
  • Firmware B:下载备份程序

    gebxjqeziky64078309340.jpg

    gebxjqeziky64078309340.jpg

    Firmware A区用来固定执行应用程序,当引导程序(BootLoader)将接收到的新固件存入到Firmware B区,并校验成功后,Firmware A区中的应用程序将被擦除,然后Firmware B区的新固件将写入到Firmware A区中。
    这种方式是比较常见的一种,因为它有Firmware B备份区,即便Firmware A区应用程序在更新(擦除)的时候突然断电,也不会影响升级,使其下载更加安全。
    嵌入型
    嵌入型就是将引导程序(BootLoader)嵌入到应用程序中去。

    z4gaokgk5a064078309440.jpg

    z4gaokgk5a064078309440.jpg

    当引导程序(BootLoader)将接收到的新固件存储到Firmware B区,在校验成功后,引导程序(BootLoader)将跳到Firmware B区去执行应用程序。
    外挂型
    外挂型就是外挂Flash或EEPROM用来存储新固件。
    当MCU内置Flash较小时,可以选择外挂存储芯片用来缓存新固件。引导程序(BootLoader)将新固件存储到外挂存储芯片中,当校验成功后,Firmware A中的应用程序将被擦除,并被写入外挂存储芯片中的新固件。

    bhneb1ymhn264078309540.png

    bhneb1ymhn264078309540.png


    那么问题来了,是不是我们可以随意划分MCU的Flash空间呢?当然不是,由于MCU的内置Flash是以块(Block)或者页(Page)为最小擦除单位,我们划分MCU内置Flash空间时必须考虑到实际MCU的块(Block)或者页(Page)的大小。
    以某单片机来举例说明“独立型”的Flash划分方式。从以下规格书中的信息可知,这颗MCU的内置Flash大小为128KB,最小的擦除页(Page)为4KB,最小的擦除块(Block)为32KB。

    fsaby4q1snk64078309640.png

    fsaby4q1snk64078309640.png

    根据以上信息,我们可以对这颗MCU的内置Flash进行如下划分:

    w32vwhfs5eo64078309740.png

    w32vwhfs5eo64078309740.png

    以上只是对固件升级(OTA)中MCU的Flash空间划分简单探讨一下,实际哪种方式更适合,还需要用户自己去评估。
    声明:本文素材来源网络,版权归原作者所有。如涉及作品版权问题,请与我联系删除。
    ------------ END ------------

    ki10zixlky364078309840.gif

    ki10zixlky364078309840.gif


    ●专栏《嵌入式工具
    ●专栏《嵌入式开发》
    ●专栏《Keil教程》
    ●嵌入式专栏精选教程

    关注公众号回复“加群”按规则加入技术交流群,回复“1024”查看更多内容。
    点击“阅读原文”查看更多分享。
  • 回复

    使用道具 举报

    发表回复

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则


    联系客服 关注微信 下载APP 返回顶部 返回列表