目录

1.硬件架构:

模块介绍:

架构图:

2.软件架构:

App:

APP下载流程:

3.对各个功能进行简单的验证

1.串口设置

2.外部flash地址分配

3.EEprom

Q&A

为什么要单独使用一个EEPROM来存储标志位?为什么不能把标志位存储在Flash里?

Flash和EEPROM的区别


1.硬件架构:

模块介绍:

Stm32F411CEU6:用于存放Bootloader代码和APP的主控芯片

Key:用于建立App和Bootloader切换逻辑模块

Led:用于演示App代码运行成功

Ch340:用于实现MCU与PC之间通信的中间模块

PC:使用相关上位机软件进行控制和下载芯片

Jlink:下载代码和Trace调试

W25Q64:存放下载备份App的代码

HC05:实现远程升级的必备工具,于PC端实现蓝牙通信

AT24C02:用来存放部分标志位信息,版本信息等

架构图:

2.软件架构:

App:

Key_Detect:用于App层是否需要跳转Bootloader命令

Led_Logic:App逻辑执行,从现象中区分APP与Bootloader

Gpio:外设寄存器层

APP下载流程:

3.对各个效果进行简单的验证

1.串口设置

Uart :

波特率:115200

协议:

远程服务器发送给MCU0x11 0x22 0x33: 请求进入下载模式

MCU接收完数据发送给用户 0x44 0x55 0x66: 询问是否立即更新

用户通过上位机发送给Mcu 0x77 0x88 0x99: 允许立即更新

2.外部flash地址分配

W25Q64

外置Flash分配两块区域A,和B,各64K

A区用于升级App更新下载固件

B区用于Bootloader备份更新的App数据,防止异常中断导致产品升级失败变砖情况

A区: Block 0 (0x000000~0x00FFFF)

B区: Block 1(0x010000~0x01FFFF)

3.EEprom

AT24C02

Page 0 用作数据存储

App代码正常: 0x00

数据正在下载: 0x11

数据已经下载完毕,请求更新: 0x22

Q&A

为什么要单独使用一个EEPROM来存储标志位?为什么不能把标志位存储在Flash里?

Flash和EEPROM的区别

FlashEEPROM非易失性存储器,意味着它们在断电后仍能保存数据。然而,它们在操作方式、存储结构和应用场景上有显著的区别。就是都

基本定义

EEPROM(Electrically Erasable Programmable Read-Only Memory)是一种电可擦除可编程只读存储器,可以逐字节或逐个位进行擦写,适用于存储需要频繁修改的少量资料。Flash(Flash Memory)是一种快速编程和擦除的存储器,通常用于存储程序和数据。

操作方式

  • EEPROM按字节操作,写入时间短,擦写次数多(一般为100万次以上)。

  • Flash按扇区处理,写入时间长,擦写次数少(一般为1万次到10万次)。

存储结构

  • EEPROM的存储单元结构复杂,成本较高,适合存储掉电保护的数据。

  • Flash的电路结构较容易,成本较低,适合用作应用存储器。

应用场景

  • EEPROM常用于存储设备序列号、校准数据等需要频繁修改的配置信息。

  • Flash常用于存储固件、操作系统等程序代码,容量较大,通常达到几GB甚至更大。

优缺点

  • EEPROM的优点是擦写次数多,适合频繁修改资料;缺点是容量小,成本高。

  • Flash的优点是容量大,成本低;缺点是擦写次数少,管理复杂。