STM32
登录
直播中
kmno4
12年用户
932经验值
私信
关注
[问答]
为什么Stm32g031芯片无法进入bootloader状态呢
开启该帖子的消息推送
芯片
bootloader
为什么
STM32
g031芯片无法进入bootloader状态呢?
为何新的Stm32g031芯片智能使用一次ISP烧写呢?
回帖
(1)
王雷
2021-11-25 10:22:04
遇到的问题如下:
1.boot0管脚拉高或拉低都不能从系统存储区(system flash)启动(即进入bootloader状态)。
2.新的Stm32g031芯片能够使用ISP烧写程序,但写完程序后就没法再次烧写了,芯片无法进入bootloader状态,只能进入main flash中,运行之前烧写的程序。
3.芯片第一次使用swd模式烧写完后设置了reset也无法进入程序区,即使按reset键也无法进入,必须得断电重启才能运行烧写的程序。
先解答问题1:因为Stm32g031芯片默认是从main flash区启动的,且默认boot0 pin 不起作用,所以不会进入bootloader状态。原因如下:
芯片的启动配置设置如下:
如上表所致,芯片的启动配置由boot_lock bit、nboot1 bit、nboot0 pin、nboot_sel bit、nboot0 bit决定。
boot_lock bit是强制从main flash区启动的配置位,默认是0,即没有强制从main flash区启动。
于是启动方式由nboot1 bit、nboot0 pin、nboot_sel bit、nboot0 bit决定。当nboot_sel bit为0时启动方式由nboot1 bit、nboot0 pin决定,即此时用户可以通过boot0管脚进行启动方式的设置,可以使用ISP下载方式。
但是很不幸的是Stm32g031芯片默认nboot_sel bit为1,即下载方式由nboot1 bit、nboot0 bit决定的,而nboot1 bit、nboot0 bit的默认值都为1,从而导致Stm32g031芯片默认是从main flash区启动的,且默认boot0 pin 不起作用。
nboot1 bit、nboot_sel bit、nboot0 bit所在寄存器地址及初始值如下:
问题1说明白了,下面解释问题2:
为何新的Stm32g031芯片可以使用ISP烧写,但也只能写一次,第二次不行了呢。原因如下:
芯片刚开始启动会检查main flash区有没有代码,要是0x08000000没有代码,就进入bootloader状态,要是有代码就从main flash区运行;
芯片使用手册原文如下:
翻译:
内部空检查标志(FLASH访问控制寄存器的EMPTY位(FLASH ACT))的实现是为了允许引导加载程序轻松地对原始设备进行编程。当BOOT0引脚将主闪存定义为目标引导区时,使用此标志。 设置该标志后,该设备将被视为空设备,并且选择了系统内存(引导加载程序)而不是主闪存作为引导区域,以允许用户对闪存进行编程。
该标志仅在Option字节加载期间更新:当地址0x0800 0000的内容读取为0xFFFF FFFF时置1,否则将其清除。 这意味着在对原始设备进行编程以在系统复位后执行用户代码之后,需要进行电源复位或将FLASH_CR寄存器中的OBL_LAUNCH位置1以清除该标志。 EMPTY位也可以直接由软件写入。
如果是第一次对设备进行编程,但未重新加载选项字节,则在系统复位后,设备仍将选择系统内存作为引导区。
通过上面的翻译我们也就明白问题3的原因了:
因为芯片首次运行进行了空位检查,此时的empty 标志位(即OBL_LAUNCH)已经置位了1,当使用swd烧写完程序后,无论是软件reset还是芯片的reset管脚复位,都无法把empty标志为清0,芯片会在每次的reset后都进入bootloader状态,而不会进入main flash区。只有断电重启,empty flag才会变成0,此时芯片才会进入main flash区运行。
在首次断电重启后,后面的swd烧写就可随意reset了。
上面3个问题已经研究清楚了,那么如何更改芯片默认的启动方式呢,根据上面的分析,我们应该更改0x1fff 7800处寄存器的nboot_sel bit为0即可使用芯片的boot0管脚来决定芯片如何启动。更改方法如下:
方法1:使用STM32CubeProgrammer更改。
1:使用STM32CubeProgrammer成功连接芯片点击主界面read,如下图;
2.读取成功后点击OB选项,然后选择User Configuration,会看的0x1fff 7800处所有bit的配置值;
3 将nboot_sel后面的勾选去掉,点击apply,配置完成(此时可能会弹出读取失败啥的,就不用管了)。断电复位,此时芯片的启动方式就由boot0引脚决定了。要是想进bootloader模式就得上拉boot0了。
.
方法2:在应用程序里改(理论上可以,但我改失败了,芯片成了砖!!!,至今不知道如何挽救)
为何理论可以改呢?因为芯片手册里对0x1fff7800寄存器起名了,且为rw状态:
St的hal库也提供了修改的库函数
于是我就按照上面的代码改了,看似合理,但执行到HAL_FLASH_OB_Launch();后芯片就成砖了,至今不知道如何挽救,哪位高手有时间,有足够的芯片研究非常欢迎,希望能告知我一下
。谢谢!
遇到的问题如下:
1.boot0管脚拉高或拉低都不能从系统存储区(system flash)启动(即进入bootloader状态)。
2.新的Stm32g031芯片能够使用ISP烧写程序,但写完程序后就没法再次烧写了,芯片无法进入bootloader状态,只能进入main flash中,运行之前烧写的程序。
3.芯片第一次使用swd模式烧写完后设置了reset也无法进入程序区,即使按reset键也无法进入,必须得断电重启才能运行烧写的程序。
先解答问题1:因为Stm32g031芯片默认是从main flash区启动的,且默认boot0 pin 不起作用,所以不会进入bootloader状态。原因如下:
芯片的启动配置设置如下:
如上表所致,芯片的启动配置由boot_lock bit、nboot1 bit、nboot0 pin、nboot_sel bit、nboot0 bit决定。
boot_lock bit是强制从main flash区启动的配置位,默认是0,即没有强制从main flash区启动。
于是启动方式由nboot1 bit、nboot0 pin、nboot_sel bit、nboot0 bit决定。当nboot_sel bit为0时启动方式由nboot1 bit、nboot0 pin决定,即此时用户可以通过boot0管脚进行启动方式的设置,可以使用ISP下载方式。
但是很不幸的是Stm32g031芯片默认nboot_sel bit为1,即下载方式由nboot1 bit、nboot0 bit决定的,而nboot1 bit、nboot0 bit的默认值都为1,从而导致Stm32g031芯片默认是从main flash区启动的,且默认boot0 pin 不起作用。
nboot1 bit、nboot_sel bit、nboot0 bit所在寄存器地址及初始值如下:
问题1说明白了,下面解释问题2:
为何新的Stm32g031芯片可以使用ISP烧写,但也只能写一次,第二次不行了呢。原因如下:
芯片刚开始启动会检查main flash区有没有代码,要是0x08000000没有代码,就进入bootloader状态,要是有代码就从main flash区运行;
芯片使用手册原文如下:
翻译:
内部空检查标志(FLASH访问控制寄存器的EMPTY位(FLASH ACT))的实现是为了允许引导加载程序轻松地对原始设备进行编程。当BOOT0引脚将主闪存定义为目标引导区时,使用此标志。 设置该标志后,该设备将被视为空设备,并且选择了系统内存(引导加载程序)而不是主闪存作为引导区域,以允许用户对闪存进行编程。
该标志仅在Option字节加载期间更新:当地址0x0800 0000的内容读取为0xFFFF FFFF时置1,否则将其清除。 这意味着在对原始设备进行编程以在系统复位后执行用户代码之后,需要进行电源复位或将FLASH_CR寄存器中的OBL_LAUNCH位置1以清除该标志。 EMPTY位也可以直接由软件写入。
如果是第一次对设备进行编程,但未重新加载选项字节,则在系统复位后,设备仍将选择系统内存作为引导区。
通过上面的翻译我们也就明白问题3的原因了:
因为芯片首次运行进行了空位检查,此时的empty 标志位(即OBL_LAUNCH)已经置位了1,当使用swd烧写完程序后,无论是软件reset还是芯片的reset管脚复位,都无法把empty标志为清0,芯片会在每次的reset后都进入bootloader状态,而不会进入main flash区。只有断电重启,empty flag才会变成0,此时芯片才会进入main flash区运行。
在首次断电重启后,后面的swd烧写就可随意reset了。
上面3个问题已经研究清楚了,那么如何更改芯片默认的启动方式呢,根据上面的分析,我们应该更改0x1fff 7800处寄存器的nboot_sel bit为0即可使用芯片的boot0管脚来决定芯片如何启动。更改方法如下:
方法1:使用STM32CubeProgrammer更改。
1:使用STM32CubeProgrammer成功连接芯片点击主界面read,如下图;
2.读取成功后点击OB选项,然后选择User Configuration,会看的0x1fff 7800处所有bit的配置值;
3 将nboot_sel后面的勾选去掉,点击apply,配置完成(此时可能会弹出读取失败啥的,就不用管了)。断电复位,此时芯片的启动方式就由boot0引脚决定了。要是想进bootloader模式就得上拉boot0了。
.
方法2:在应用程序里改(理论上可以,但我改失败了,芯片成了砖!!!,至今不知道如何挽救)
为何理论可以改呢?因为芯片手册里对0x1fff7800寄存器起名了,且为rw状态:
St的hal库也提供了修改的库函数
于是我就按照上面的代码改了,看似合理,但执行到HAL_FLASH_OB_Launch();后芯片就成砖了,至今不知道如何挽救,哪位高手有时间,有足够的芯片研究非常欢迎,希望能告知我一下
。谢谢!
举报
更多回帖
rotate(-90deg);
回复
相关问答
芯片
bootloader
stm32G031
串口外部不接上拉电阻,导致
stm32
进入
到了硬件中断怎么解决?
2024-03-13
103
是否可以将14.7456MHz晶体与
STM32G031
(LQFP32) 一起使用?
2022-12-30
169
STM32L031
无法
进入
boot
2018-12-12
3404
为什么使用
STM32G031
ADC采集的数值一直为0
呢
2021-12-02
1998
STM32G031
k8t6串口发送为什么会
进入
硬件中断?
2024-03-13
108
如何解决使用Nucleo
STM32G031
K8和uVision的WFI()问题?
2023-01-06
160
使用
STM32G031
运行CRC计算但结果不匹配是哪里出问题了
2022-12-13
154
为什么
无法
使用
STM32
CubeProgrammer和ST-LINK/V2闪存
STM32G031
(8 引脚)?
2023-02-09
453
Nucloe-
G031
K板的重置按钮不起作用怎么解决?
2023-01-10
175
请问
STM32G031
K LL库怎么使用?
2021-11-25
593
发帖
登录/注册
20万+
工程师都在用,
免费
PCB检查工具
无需安装、支持浏览器和手机在线查看、实时共享
查看
点击登录
登录更多精彩功能!
首页
论坛版块
小组
免费开发板试用
ebook
直播
搜索
登录
×
20
完善资料,
赚取积分