新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > HardFault_Handler問題查找方法

        HardFault_Handler問題查找方法

        作者: 時間:2013-03-25 來源:網絡 收藏

        STM32出現故障的原因主要有兩個方面:

        本文引用地址:http://www.104case.com/article/148066.htm

        1、內存溢出或者訪問越界。這個需要自己寫程序的時候規范代碼,遇到了需要慢慢排查。

        2、堆棧溢出。增加堆棧的大小。

        出現時排查的

        發生異常之后可首先查看LR寄存器中的值,確定當前使用堆棧為MSP或PSP,然后找到相應堆棧的指針,并在內存中查看相應堆棧里的內容。由于異常發生時,內核將R0~R3、R12、Return address、PSR、LR寄存器依次入棧,其中Return address即為發生異常前PC將要執行的下一條指令地址。

        注意:寄存器均是32位,且STM32是小端模式。(參考Cortex-M3權威)

        編寫代碼如下:

        void StackFlow(void)

        {

        int a[3],i;

        for(i=0; i10000; i++)

        {

        a[i]=1;

        }

        }

        void SystemInit(void)

        {

        /* Reset the RCC clock configuration to the default reset state ------------*/

        /* Set HSION bit */

        RCC->CR |= (uint32_t)0x00000001;

        /* Reset CFGR register */

        RCC->CFGR = 0x00000000;

        /* Reset HSEON, CSSON and PLLON bits */

        RCC->CR = (uint32_t)0xFEF6FFFF;

        /* Reset PLLCFGR register */

        RCC->PLLCFGR = 0x24003010;

        StackFlow();

        /* Reset HSEBYP bit */

        RCC->CR = (uint32_t)0xFFFBFFFF;

        。。。。。。。。。。。。。。

        }

        DEBUG如下圖

        SP值為0x20008560,查看堆棧里面的值依次為R0~R3、R12、Return address、PSR、LR, 例如R0(10 27 00 00), 顯然堆棧后第21個字節到24字節即為Return address,該地址0x08001FFD即為異常前PC將要執行的下一條指令地址(即StackFlow()后面的語句處 RCC->CR = (uint32_t)0xFFFBFFFF)

        另一種

        默認的處理不是B .這樣的死循環么?樓主將它改成BX LR直接返回的形式。然后在這條語句打個斷點,一旦在斷點中停下來,說明出錯了,然后再返回,就可以返回到出錯的位置的下一條語句那兒

        __asm void wait()

        {

        BX lr

        }

        void (void)

        {

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

        wait();

        }



        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 霍林郭勒市| 满城县| 巢湖市| 新闻| 东港市| 佛山市| 康定县| 安国市| 宁海县| 镇巴县| 溧阳市| 永兴县| 福海县| 大埔区| 竹北市| 扬中市| 永吉县| 义乌市| 晋城| 五常市| 静安区| 河曲县| 格尔木市| 西藏| 禄丰县| 诏安县| 巴马| 博兴县| 松阳县| 哈巴河县| 韶山市| 包头市| 鹿邑县| 出国| 威海市| 来宾市| 霍城县| 晋城| 兰西县| 海宁市| 陆河县|