历史上的今天
返回首页

历史上的今天

今天是:2025年06月14日(星期六)

2019年06月14日 | stm32重启调试笔记

2019-06-14 来源:eefocus

#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堆栈来进行查看是否已经溢出。


    结束


    推荐阅读

    史海拾趣

    Holy Stone公司的发展小趣事

    1999年,Holy Stone在台湾桃园龙潭设立了生产基地,开始自主生产积层陶瓷电容(MLCC)。这一举措标志着公司从单纯的代理商向集研发、生产、销售于一体的多元化企业转型。同年,公司创立了自有品牌“HEC”,并以该品牌推出了一系列多元客制化产品,行销全球。这些产品凭借其高品质和满足客户全方位需求的特点,赢得了客户的广泛信赖,进一步巩固了公司在电子元件市场的地位。

    岑科(CENKER)公司的发展小趣事

    在过去,国内企业在车载信号传输领域的共模电感选择有限,主要依赖进口品牌。岑科意识到这一市场的巨大空缺后,决定借助自主研发设备的优势进行研发工作。经过两三年的攻关,岑科成功研发出了ACML系列共模电感。这一系列产品在温度特性上表现优异,可在-40℃到150℃的范围内正常工作,并适用于CAN-BUS、CAN-FD、A2B及以太网等多种场景。岑科的这一研发成果不仅填补了国内市场空白,还实现了国产替代,为汽车电子行业的发展做出了重要贡献。

    Danaher Corporation公司的发展小趣事

    随着全球化趋势的加强,丹纳赫集团开始积极拓展国际市场。通过在全球各地设立研发中心、生产基地和销售网络,丹纳赫集团成功地将产品和服务推向了全球市场。同时,丹纳赫集团还加强了与国际知名企业的合作,共同开发新技术和产品,进一步巩固了其在电子行业中的领先地位。

    以上五个故事梗概概述了丹纳赫集团在电子行业中的发展历程和关键节点。如需更详细的信息和故事背景,建议查阅丹纳赫集团的官方资料或相关新闻报道。

    Hi-Tech Resistors Pvt Ltd公司的发展小趣事

    自上世纪80年代起,丹纳赫集团通过一系列的战略并购,逐渐扩大其在电子行业的影响力。这些并购不仅为丹纳赫集团带来了先进的技术和产品,还增强了其在全球市场的竞争力。其中,对Leica显微系统公司的收购标志着丹纳赫集团正式涉足生命科学业务,为其在电子显微镜和生命科学仪器领域的发展奠定了基础。

    友盟(AP)公司的发展小趣事

    在追求商业成功的同时,友盟(AP)公司也积极履行社会责任,致力于可持续发展。公司关注环境保护、公益事业等方面的问题,积极参与相关活动和项目。同时,友盟还通过技术创新和产品优化,推动电子行业的绿色发展和数字化转型。这些努力不仅提升了公司的社会形象,也为其未来的发展注入了新的动力。

    以上是关于电子行业里友盟(AP)公司发展起来的5个相关故事。这些故事从不同角度展现了友盟在技术创新、合作伙伴关系、市场拓展、人才团队建设以及社会责任等方面的努力和成就。当然,每个公司的发展都是一个复杂而多元的过程,这些故事只是其中的一部分。

    Excelsys公司的发展小趣事

    随着全球对环保意识的日益增强,Excelsys公司积极响应绿色环保的号召,将环保理念融入到产品设计和生产过程中。公司采用环保材料、优化生产工艺、提高能源利用效率等措施,减少了对环境的影响。同时,公司还积极参与环保公益活动,为行业的绿色发展贡献力量。

    问答坊 | AI 解惑

    搞手帮个忙

    我手上有个电路板,上面有个编码按钮,就是按钮能在1-9这间选择10个数字中的某一个,每按一下数字就加一(或减一),这个按钮有五个管脚。 请问这是个什么按钮,叫什么名字?还有就是他的原理。谢谢了。…

    查看全部问答>

    关于mini2440摄像头的问题

    谁做过友善之臂的摄像头的应用程序?在Linux下怎么查看摄像头的设备名?…

    查看全部问答>

    prom加载问题求教

    fpga为xcs200-pq208,prom为xc18v02-vq44.9 w3 x7 j  F2 v1 M# S+ W\' }( G7 A目前情况为,已经生产prom文件,通过jtag扫描只能看到fpga,看不到prom。在手动添加prom和fpga后,可以对fpga加载。却不能对prom加载,提示idcode不符。如果i ...…

    查看全部问答>

    日企力推3D电视疑为设局 中韩企业警惕产业前端遭暗算

    本帖最后由 jameswangsynnex 于 2015-3-3 19:57 编辑 3D可真够热的,日本企业挑头,中韩企业也在迅速跟进,从今年初在美国展示,到现在已实现了对欧美、中韩等主要消费电子市场的产品销售,短短数月便在全球范围内掀起了一股热潮并演绎成一种社会 ...…

    查看全部问答>

    PXA310的SPI控制MCP2515不能读取?

    采用的是PXA310的SPI控制MCP2515, 发送是正常的。通过命令字写到2515后,然后读芯片状态寄存器。 功过示波器观察MISO脚信号是正常的,可是读PXA_SSDR寄存器却总是0。代码如下所示: for (i = 0; i < len; i++) { SPI_CtrlBlk.pSPIReg->PXA_ ...…

    查看全部问答>

    omap3503简单问题,初学,大家指教。

    拿到一块ti的3503 evm板,粗略看了3503的datasheet。 问题:1、3503不包括dsp核?但是用在手机上一般是要音视频处理的,是不是把dsp和做在板子上当外设用了,          还是根本就不需要dsp?    &nb ...…

    查看全部问答>

    终于搞定MDK+JLINK了

    JLINK被称作是调试ARM的“神器”,其速度和可靠性那是无容置疑的MDK作为Keil的产品,其界面的易用性那是很多从Keil C51过来的工程师首选的。IAR的性能好是好,光一个启动速度超级慢,就够人受的了MDK+JLINK方法:1、安装Keil支持JLINK的 ...…

    查看全部问答>

    STM32系列的低功耗是否能够媲美MSP430?

                                     最近公司想开发无线传感网采集终端设备(每分钟采集一次),要求通过ZIGBEE无线传输,只能通过1节锂电池供电,并且 ...…

    查看全部问答>

    跪求好心人指导基于avr的煤气泄漏检测系统的程序代码···

    跪求好心人指导基于avr的煤气泄漏检测系统的程序代码···…

    查看全部问答>