keil5 调试不进主函数main(),一直卡在0x1FFFF3AA F8D01808 LDR r1,[r0,#0x808]

使用stm32f103vet6板子仿真调试的时候,可以识别到JLINK,进入硬件仿真界面后无法进入main()函数,一直循环执行以下三行代码,无法正常运行,也无法进入断点:

0x1FFFF3AA  F8D01808  LDR      r1,[r0,#0x808]

0x1FFFF3AE  0549      LSLS     r1,r1,#21

0x1FFFF3B0  D5FB      BPL      0x1FFFF3AA

1.原因:

BOOT0和BOOT1的连接有问题;

2.解决方法:

将BOOT1悬空;

将BOOT0接10k下拉电阻,然后接地;

3.解释:

STM32三种启动模式对应的存储介质均是芯片内置的,它们是:

(1)主Flash
主Flash起始地址为0x08000000,它指的是STM32内置Flash,通常我们烧录的代码就是存放在这个位置。

(2)系统存储器
系统存储器起始地址为0x1FFF0000,这种模式启动的程序功能是由芯片厂家设置的,STM32在出厂时会这个区域内置一段BootLoader, 也就是我们常说的ISP程序, 这是一块ROM,出厂后无法修改。我们要使用的DFU就是放在这里。

(3)SRAM = 芯片内置的RAM区,就是内存啦。几乎不用这种模式

 
在每个STM32的芯片上都有两个管脚BOOT0和BOOT1,这两个管脚在芯片复位时的电平状态决定了芯片复位后从哪个区域开始执
行程序,见下表:
BOOT1=x(悬空)   BOOT0=0   从用户闪存启动,这是正常的工作模式。
BOOT1=0   BOOT0=1   从系统存储器启动,这种模式启动的程序功能由厂家设置。
BOOT1=1   BOOT0=1   从内置SRAM启动,这种模式可以用于调试。

总而言之,BOOT0和BOOT1引脚是STM32微控制器中用于控制启动模式和引导加载程序的关键引脚。通过控制这些引脚的状态,可以选择从哪个存储器中加载程序,并使用引导加载程序来初始化系统。这样可以实现多种启动模式和引导加载程序,并且对于开发人员来说,这是非常有用的功能。

  • 10
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值