datasheet

stm32重启调试笔记

2019-06-14来源: eefocus关键字:stm32  重启  调试笔记

#stm32重启调试笔记

本文章主要解决在使用stm32+ucos进行嵌入式软件开发中遇到的系统重启现象查找与解决。


1 、重启原因

系统重启又多种可能:1、看门狗中断;2、内存泄漏;3、软件重启。

首先看一下stm32的手册关于系统重启的状态寄存器,其中详细的记录了几个系统重启的原因(低功耗复位标志、窗口看门狗复位标志、)


寄存器详细信息:


在这里插入图片描述在这里插入图片描述在这里插入图片描述

    查看寄存器值

    a:通过debug查看,在代码进入main函数时加入断电,通过查看RCC寄存器值可以明了的查看相关状态


    在这里插入图片描述


    b:在查看之后应该清除中断信息,这样下次重启时才能知道重启原因。加入下面一条语句。


    /*打印中断标志字*/

    void print_reboot_flag(void)

    {

    printf("reboot flag :0x%04Xrn",RCC->CSR); //

    /*判断并打印重启原因*/

    if(RCC->CSR & 1<<31){

    printf("reboot error:Low-power!rn"); //低功耗管理

    }else if(RCC->CSR & 1<<30){

    printf("reboot error:Window watchdog!rn"); //窗口看门狗

    }else if(RCC->CSR & 1<<29){

    printf("reboot error:Independent watchdog!rn"); //独立看门狗

    }else if(RCC->CSR & 1<<28){

    printf("reboot error:Software!rn"); //软件复位

    }else if(RCC->CSR & 1<<27){

    printf("reboot error:POR/PDR!rn"); //por/pdr复位

    }else if(RCC->CSR & 1<<26){

    printf("reboot error:PIN!rn"); //NRST引脚复位

    }else if(RCC->CSR & 1<<25){

    printf("reboot error:BOR!rn"); //软件写入RMVF位清零

    }

    }

    /*清除中断标志字*/

    void clear_reboot_flag(void)

    {

    RCC->CSR |= 1<<24; //清除

    }

    /*printf()函数位相应的打印输出定向函数*/



    2、重启问题解决

    重启原因找到了,下面就是解决重启问题,上面标识的重启原因基本是比较容易解决的。


    看门狗重启


    出现看门狗异常可能性比较多,程序运行正常软件喂狗超时,这种情况最好解决,查看喂狗时间可软甲是否有超时的。

    还有一种情况是内存溢出这种问题是作为C/C++程序员来说是最为头痛的问题。下面单独讲一讲出现这种现象是应该向哪个方向去查找。


    内存溢出越界访问


    内存溢出也就是会出现程序跑飞,在stm32中常常会出现HardFault_Handler中断,这种异常也是有两种可能。


    a 有规律的异常HardFault_Handler中断,这种相对而言是比较容易发现的。比如下面一段代码


      int main(void)

      { 

      uint8_t *str;

      while(1)

      {

      *str++ = 1; 

      }

      }


    在代码中我们对位分配内存的指针进行了操作,程序运行我们将断电放在HardFault_Handler中断中,


      void HardFault_Handler(void)

      {

        /* Go to infinite loop when Hard Fault exception occurs */

        while (1) //在此处加断电

        {

        }

      }


    程序会卡死在断点处。


    1)

    通过下面图片显示的,在Call Stack中查看在什么地方出现了异常。使用"Show Caller Code"查看相关代码,同时通过查看此处的相关的数据。


    在这里插入图片描述

    在这里插入图片描述
    在这里插入图片描述

    2)

    通过查看芯片寄存器来手动查找出现异常的代码位置


    首先查看R14(LR)寄存器

    0xFFFFFFF9对应的是要看MSP寄存器

    0xFFFFFFFD对应的是要看PSP寄存器

    然后对应的通过 MSP或者PSP的寄存器值,在Memory中查到运行地址,然后在Disassembly中查找地址位置。


    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    b

    在出现不规律的重启现象是就比较让人捉急了,此处记录一下个人在开发中遇到的几个重启问题。


    重启的情况


    1、函数内部变量过多使栈内存溢出,这种情况需要增加栈大小heap,在startup_xxx.s文件中。


      Heap_Size       EQU     0x00000200

    1

    2、带任务的工程项目中也可能是出现了堆栈溢出,这种情况可以通过打印free堆栈来进行查看是否已经溢出。


    结束


    关键字:stm32  重启  调试笔记

    编辑:什么鱼 引用地址:http://www.eeworld.com.cn/mcu/ic464661.html
    本网站转载的所有的文章、图片、音频视频文件等资料的版权归版权所有人所有,本站采用的非本站原创文章及图片等内容无法一一联系确认版权者。如果本网所选内容的文章作者及编辑认为其作品不宜公开自由传播,或不应无偿使用,请及时通过电子邮件或电话通知我们,以迅速采取适当措施,避免给双方造成不必要的经济损失。

    上一篇:STM32开发笔记57: 复位电路设计
    下一篇:STM32程序软件复位

    关注eeworld公众号 快捷获取更多信息
    关注eeworld公众号
    快捷获取更多信息
    关注eeworld服务号 享受更多官方福利
    关注eeworld服务号
    享受更多官方福利

    推荐阅读

    学习STM32CubeMX与HAL库吐槽

    最近因为一个小项目(智能穿戴),用到了STM32L0(低功耗 Cortex M0)系列的MCU,查了官网,居然没有提供固件库,只有HAL库,于是STM32CubeMX生成了HAL库的工程,学习HAL的使用:STM32CubeMX与HAL库的优点:1、降低了使用外设的门槛,所有时钟设置等一目了然。2、统一了代码的架构、风格,让源代码的可读性“保底线“提高。吐槽如下:1、工程的架构很死了,只能在框框条条里填写内容,这完全违背了C程序员们的习惯。例如,要自己加上OS,代码结构会很难看。2、但一但遇上了坑,就无法解决。3、依赖性更高了,而且这工具有BUG,例如:在生成代码时,终止STM32CubeMX,所有源代码会全部消失,自己写的代码
    发表于 2019-06-18

    STM32CubeMx(Keil5)开发之路——1配置第一个项目

    运行环境Windows10STM32CubeMX___Version 5.0.0Keil5(MDK5)___Version 5.15简介本例程主要搭建第一个项目,并且完成最基本的项目所需配置,后续的教程都基于这篇教程。STM32CubeMx配置新建项目搜索自己芯片的型号点击选择封装形式选择外部晶振可以根据需求调节各个总线的时钟频率(就具体情况而定)DEBUG选项选择"Serial Wire"(4线烧录,CLK,DIO,VCC,GND)你会看到芯片引脚会占用这几个引脚,就是烧录用的CLK和DIO点击"Project Manager"修改项目名称修改项目保存路径选择编写工具(我使用Keil5
    发表于 2019-06-18
    STM32CubeMx(Keil5)开发之路——1配置第一个项目

    STM32CubeMX(Keil5)开发之路——9设置微秒级别的延时

    运行环境Windows10STM32CubeMX___Version 5.0.0Keil5(MDK5)___Version 5.15简介本例程主要讲解如何对芯片内的Flash进行读写,用芯片内部Flash可以对一些需要断电保存的数据进行保存,无需加外部得存储芯片,本例程采用的是STM32F103ZET6,512K大小的Flash。STM32CubeMx基本配置基础配置过程请参考 STM32CubeMx(Keil5)开发之路—配置第一个项目printf重定向例程请参考 STM32CubeMx(Keil5)开发之路——3发送USART数据和printf重定向STM32CubeMx PWM配置1——点击TIM3进行设置2——选择
    发表于 2019-06-18
    STM32CubeMX(Keil5)开发之路——9设置微秒级别的延时

    STM32CubeMX(Keil5)开发之路——7输出PWM

    运行环境Windows10STM32CubeMX___Version 5.0.0Keil5(MDK5)___Version 5.15简介本例程主要讲解如何设置PWM这只输出4路PWM信号STM32CubeMx基本配置基础配置过程请参考 STM32CubeMx(Keil5)开发之路—配置第一个项目STM32CubeMx PWM配置1——点击TIM2进行设置2——4个Channel都选择 “PWM Generation CHx” 选项3——预分频值填72-1即714——自动重装载值设置为100-1也就是995——会看到相应的输出管脚PA0——PA3就是PWM的输出管脚讲解:PWM波的频率=时钟频率/(预分频+1)/(自动重装载值
    发表于 2019-06-18
    STM32CubeMX(Keil5)开发之路——7输出PWM

    关于STM32像EPROM一样可以单字节写内部Flash的理解

    都有说STM32的内部Flash可以像EPROM一样操作,单个字节单个字节的写入。根据本人的拙见,其实也就仅仅是“像”而已。原因有以下几点:1.首先Flash这种东西,其写入数据的原理是便是将1变成0,所以你的某地址Flash一旦已经写过数据而且不为0,则当你再次需要向该地址写数据时,必须要先擦除,即把该地址先全部变成1,否则你将数据写入该地址后,基本上该地址里面的值已经不是你写入的值了。2.STM32对内部Flash有页(1k或者2K)擦除指令,也就是STM32不能单独对某一个或者某几个字节进行擦除。而擦除操作并不需要大量内存。3.如果要像EPROM一样操作Flash,其原理是先把该一页里面的数据全部读到一个buf里面,如果
    发表于 2019-06-18

    STM32的ISP升级详解

    最近在做一个给STM32用ISP升级的项目,接触到STM32厂家烧录的Bootloader工作流程,具体官方文档稍后上传供大家参考,也可去ST官网下载文档。接下来针对文档中部分内容分析其工作过程:一、要进入该模式,需把STM32硬件上的BOOT0引脚拉高(置1),BOOT1拉低(置0),对此部分不明白的可以查阅STM32BOOT引脚的资料(网上一搜一大堆),不过多阐述。两个引脚配置好对STM32复位,其在4个时钟周期内会自动检测BOOT引脚相应的配置情况,进入相应模式(原厂Bootloader模式)下工作,此时已经到达此次旅行的起点——USART Bootloader 模式此处要特别注意的是硬件上一定要用原厂规定的串口才能完成
    发表于 2019-06-18
    STM32的ISP升级详解

    小广播

    何立民专栏

    单片机及嵌入式宝典

    北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

    电子工程世界版权所有 京ICP证060456号 京ICP备10001474号 电信业务审批[2006]字第258号函 京公海网安备110108001534 Copyright © 2005-2019 EEWORLD.com.cn, Inc. All rights reserved