原创 stm32 在线升级的惨痛经历

2019-10-14 14:35 1435 9 2 分类: MCU/ 嵌入式 文集: mcu

一、问题

在成功实现了程序定时在APP和IAP之间来回切换后,以为已经掌握了stm在线升级的秘诀,于是兴冲冲的开始改公司的升级程序。结果,发现程序可以从IAP跳转到APP,但是程序会跑飞。在进入APP模式后,结束调试时,会自动跳转到一下界面。

尝试调试无数次,依然没有进展,而且毫无办法,不知道哪里出了问题。

二、尝试解决与交叉验证

1、将APP程序替换成之前的亮灯程序,然后进行更新,更新完毕后,APP程序正常运行。此步骤验证了IAP程序是可以正常跳转的。

2、先进行IAP在线升级,将APP程序通过升级的方式烧录到FLASH,然后写入之前可以正常工作的已有的IAP程序。发现APP正常工作,此方法可以验证通过升级的方式写入的APP程序是正确和完整的。

3、通过以上步骤的交叉验证,可以证明IAP和APP程序都是正确的。那么问题出在哪里呢??

4、尝试在现有的APP程序里,添加入之前可以正常工作的led亮灯的APP程序,屏蔽掉与亮灯程序无关的代码。然后通过在线升级的方法写入修改过的APP程序,结果发现IAP可以成功跳转到APP部分,且APP工作正常;

5、逐步添加APP里被屏蔽掉的代码,并逐步删除新加入的LED亮灯有关的代码,看是从哪一步骤开始,APP代码不能正常工作;

6、为了快速验证,先后写入IAP和APP程序。在IAP程序里 只通过定时的方式,定时切换到APP程序。观察IAP是否可以跳转,APP程序是否可以工作。

三、问题点

经过以上步骤,发现在删除定时器2的中断处理函数后,IAP可以跳转,但APP会跑飞。

原因:

1、在IAP程序里,我开了定时器2,在跳转前关闭了总中断;这个是与之前已有的IAP程序不一样的地方,之前代码是用了定时器3;

2、在IAP跳转到APP后,重新打开了总中断。这个时候,定时器2又重新开始工作,但是在我的APP程序里,因为没有用定时器2,所以没有写定时器2的中断处理函数,所以程序会跑飞。

四、 总结

1、在跳转前,一定要把已经使用到的外设全部关闭。比如

__disable_irq();

TIM_Cmd(TIM2,DISABLE );

GotoAPPMain();

2、在所有的外设声明前,一定要先复位,比如

TIM_DeInit (TIM3 );

3、最好定时器的功能都用的一致,比如IAP和APP都用定时器2 或者定时器3,不要一个用定时器2 ,另一个用定时器3。

PARTNER CONTENT

文章评论1条评论)

登录后参与讨论

curton 2019-10-15 19:50

学习了
相关推荐阅读
minicaihong 2020-10-22 16:44
场效应管放大电路的直流偏置电路详解
什么是偏置电路晶体管构成的放大器要做到不失真地将信号电压放大,就必须保证晶体管的发射结正偏、集电结反偏。即应该设置它的工作点。所谓工作点就是通过外部电路的设置使晶体管的基极、发射极和集电极处于所要求的...
minicaihong 2020-10-22 16:37
场效应管偏置电路-场效应管偏置电路的工作原理及作用分析
什么是偏置电路晶体管构成的放大器要做到不失真地将信号电压放大,就必须保证晶体管的发射结正偏、集电结反偏。即应该设置它的工作点。所谓工作点就是通过外部电路的设置使晶体管的基极、发射极和集电极处于所要求的...
minicaihong 2020-10-22 16:27
MOS管偏置电路-MOS管直流、恒流等偏置电路图文及方程详解
MOS管偏置电路MOS管直流偏置电路MOS管的单电源直流偏置电路有两种:1、只能用于结型和耗尽型MOS管的自给偏置电路。2、可用于各种MOS管的分压式偏置电路自给MOS管偏置电路(1)图解法根据图中电...
minicaihong 2020-05-27 09:50
sprintf 格式化字符串
sprintf 格式化字符串好久没写博客了,又遇到自己觉得很傻的问题,格式化字符串还要找下定义和用法sprintf() 函数把格式化的字符串写入变量中。arg1、arg2、++ 参数将被插入...
minicaihong 2020-05-25 15:07
12T和1T的单片机
标准51是12T的,就是说12个时钟周期(晶振周期,例如12M的,周期是1/12M,单位秒),机器做一个指令度周期,刚好就是1/12M*12=1uS,常见指令例如nop就是一个周期,刚好1uS,其他的...
minicaihong 2020-05-23 16:22
4HC595驱动8*8点阵屏
74HC595驱动8*8点阵屏置顶 菜袅1号 2020-05-19 10:00:03   52   收藏展开该项目使用国产M0核单片机,驱动方式类似于stm32平台;点阵驱动芯片:...
EE直播间
更多
我要评论
1
9
关闭 站长推荐上一条 /3 下一条