STM32 ISP下载原理

简介

**‌ISP‌(In-System Programming,系统内编程)**指无需将芯片从电路板上取下,就能对芯片内部的Flash存储器进行编程或擦除的技术。通常通过芯片出厂时自带的Bootloader实现,例如使用UART、USB等接口进行烧录。这种方式常用于产线初始烧录或重大版本升级。‌

**‌IAP‌(In-Application Programming,应用内编程)**指芯片在运行程序时,通过软件机制对自身Flash存储器进行修改的技术。工程师需要自行编写Bootloader,将Flash分为系统代码和用户代码区域,实现程序的动态下载和执行。这种方式支持设备固件的在线升级,适用于资源受限的嵌入式系统(如传感器、无线模块)。‌

STM32的ISP下载过程

第1步:先设置BOOT1和BOOT0从系统区启动

第2步:复位STM32芯片,执行系统中预设的程序(系统程序会将接受到的数据写到FLASH中)

第3步:主机通过串口发送要下载的hex文件给STM32

第4步:系统预设的程序接收到hex后将其烧录到用户区flash中

第5步:设置BOOT1和BOOT0为从用户区启动,然后复位重启(复位)执行刚才下载的hex即可。

STM32的BOOT1和BOOT0与启动区的关系

以上表格显得过于复杂,了解就行。只需要知道2个BOOT引脚设置如下:

(1)BOOT1始终为0

(2)BOOT0在ISP时要先为1,就是从系统存储区启动,也就是程序下载。

然后BOOT0为0,就是从主闪存存储器运行,也就是程序运行。

CH340下载电路的分析

通过CH340芯片的RTS和DTR引脚来改变BOOT0、RESET的高低电平

RTS和DTR引脚输出的有效电平为低电平。准备发送数据时RTS输出低电平,数据发送完成时DTR输出低电平。

RTS输出低电平,DTR输出高电平时,三极管Q2导通,RESET会输出低电平,STM32复位

RTS输出低电平时,三极管Q3导通,BOOT0会输出高电平,STM32执行系统启动程序

RTS输出高电平时,三极管Q3阻断,BOOT0通过电阻到地,为低电平,STM32执行FLASH启动程序,同时三极管Q2阻断,RESET为无效电平高电平

相关推荐
Jason_zhao_MR5 小时前
RK3576 MIPI Camera ISP调试:主观调优与工程实战(下)
stm32·嵌入式硬件·安全·系统架构·嵌入式
ACP广源盛139246256738 小时前
iOS 27 开放 AI 生态@ACP#小型化扩展黄金风口,IX8008全面超越 ASM2806,铸就嵌入式 AI 扩展核心
人工智能·嵌入式硬件·macos·ios·计算机外设·objective-c·cocoa
smartpi_ai8 小时前
玩具产品从按键控制升级为语音控制:语音模块与MCU串口通信实战
单片机·嵌入式硬件
BreezeJuvenile10 小时前
【STM32】时钟摘取法
stm32·单片机·嵌入式硬件
崇山峻岭之间10 小时前
单片机GPIO配置
单片机·嵌入式硬件
不会武功的火柴10 小时前
SystemVerilog语法(7)-接口(interface)
嵌入式硬件·fpga开发·仿真·ic验证·rtl
深圳英康仕11 小时前
五网口六USB:一台龙芯2K3000工控机的接口配置解读
嵌入式硬件·信创·工控机·工业计算机·龙芯2k3000
lllllllccccc12 小时前
FReeRtos中断管理、临界段保护和任务调度器挂起和恢复学习
单片机·嵌入式硬件
ACP广源盛1392462567312 小时前
IX8024 对标 ASM2824 @ACP#搭配昆仑芯 P800 构建 AI 服务器 PCIe4.0 高速互联架构
网络·人工智能·嵌入式硬件·电脑
踏着七彩祥云的小丑13 小时前
嵌入式测试学习第 15 天:逻辑门基础:与或非、简单逻辑电路
单片机·嵌入式硬件