STM32F10在iap和app模式下,调试模式串口可以通信,下载后却不能通信的问题

开发环境iar for arm ,开发芯片是STM32F103
问题点:在调试模式下,usart1可以接受和发送数据,但是下载到芯片内部时,或者使用iap升级之后就出现数据无法接受的问题。

第一就像想到的启动文件和中断向量表没有配置好:
如图所示:ICF配置
STM32F10在iap和app模式下,调试模式串口可以通信,下载后却不能通信的问题
STM32F10在iap和app模式下,调试模式串口可以通信,下载后却不能通信的问题
对比之前的工程,和百度上的搜索结果发现是对的。
经过非常痛苦的焦虑之后,开始冷静下来,想想到底怎么回事、如何查找。
第一:我的配置确认没错,启动文件和icf文件都是正确的。
第二:既然usart1在调试下可以接受说明基本的配置没有错误,既然下载后不能用,说明他的中断在其他地方被取消掉了。问题是什么地方和usart可以用同意部分资源呐,调试和下载后就多了iap部分的影响,而iap和app的程序的初始化有一部分是重叠的。所以对比iap和app程序吧。。。。

突然间发现我的iap里面的wifi通信使用的是usart1,但是数据接收使用了DMA缓冲。。。
在我app里面不需要使用wifi通信,所以就直接用usart1中断接收了。。。
问题来了:iap初始化好了之后,先判断是否存在升级标志,在判断是否存在app,然后进入app,着中间是没有间断(CPU一直在运行),所以有一些被启用的外设是保持的,除非在app初始化里面被重新配置了。。。既然iap里面用了DMA接收usart1数据,app里面就是没用也应该disable。。。
改完发现好了。。。

血的教训:iap和app里面的上电初始化一定要仔细对比,iap内部保存的初始化要确保在app里面被屏蔽或者重新初始化。

废话太多了!