chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

工程師筆記|一個地址未對齊引起的 HardFault 異常

STM32單片機 ? 來源:未知 ? 2023-02-10 11:05 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

關(guān)鍵詞:地址對齊,Hardfault,STM32G0





目錄預覽




1. 概述

2. 問題描述與分析

3. 問題解決

4. 總結(jié)



1.概述

客戶在使用 STM32G070 的時候,KEIL MDK 為編譯工具,當編譯優(yōu)化選項設(shè)置為Level0 的時候,程序會出現(xiàn) Hard Fault 異常,而當編譯優(yōu)化選項設(shè)置為 Level1 的時候,則程序運行正常。


表面上看,這似乎是 KEIL MDK 的問題,通過分析,導致這個問題的本質(zhì)原因是內(nèi)存地址沒有對齊引起的,下面章節(jié)將詳細分析該問題的來龍去脈以及解決方法。


問題描述與分析

根據(jù)客戶的反饋,引起問題的代碼很簡單,客戶定義了幾個全局數(shù)組,在主程序中訪問這幾個數(shù)組就會出現(xiàn) Hard Fault 異常,參考代碼如下。


把客戶提供的代碼片段移植到 NUCLEO-G070RB 開發(fā)板上,問題很容易就復現(xiàn)了,代碼本身功能簡單,寫法上也沒有錯誤,所以從代碼片段本身上看,無法確定問題出在哪里,通過 KEIL 調(diào)試器,在匯編窗口單步調(diào)試下,最終發(fā)現(xiàn)導致 HardFault 異常的語句為下圖所示語句。


根據(jù)單步調(diào)試得知出現(xiàn)問題的語句為 LDR 指令,參考 Cortex M0 編程手冊 PM0223 得知 LDR 指令的作用是從內(nèi)存地址中加載一個 WORD 數(shù)據(jù)到目的寄存器 Rt 中,其中內(nèi)存地址根據(jù) Rn 或者 SP 寄存器的值以及立即數(shù) imm 得到。


根據(jù)指令的描述,使用 LDR 指令的時候,通過 Rn 和 imm 計算得到的內(nèi)存地址必須是讀取字節(jié)數(shù)的倍數(shù),LDR 每次讀取一個 WORD,所以使用 LDR 指令時,內(nèi)存地址必須 4字節(jié)對齊。如果地址沒有對齊,則會導致 HardFault 異常。


結(jié)合 LDR 指令的描述,在調(diào)試狀態(tài)下,通過查看寄存器值,圖 2 出錯語句中根據(jù) Rn和 imm 計算得到的內(nèi)存地址為 R0=0x2000000B,imm=4 所以內(nèi)存地址為 0x2000000F,很顯然這個地址不是 4 字節(jié)對齊的。



而當我們改變編譯優(yōu)化選項為 Level1 時,得到的內(nèi)存地址為R0=0x20000000,imm=0x04 顯然這個地址是按照 4 字節(jié)對齊的,所以這種情況下是不會出現(xiàn) HardFault 異常的,印證了客戶的問題現(xiàn)象。



3.問題解決

通過上一節(jié)的分析,明確了導致該問題的本質(zhì)原因是內(nèi)存地址沒有對齊,這個內(nèi)存地址實際上是代碼中定義的全局變量 g_curPlaySound_app 指向的地址,也就是全局數(shù)組變量 SoundFile 的地址,在編譯器不同的優(yōu)化選項下,分配給 SoundFile 變量的地址是不一樣的,在本案例中,編譯優(yōu)化選項 Level0 條件下,SoundFile 分配的地址沒有按照WORD 對齊,而在優(yōu)化選項 Level1 條件下,SoundFile 分配的地址是 WORD 對齊,所以在兩種優(yōu)化選項下,出現(xiàn)了不一樣的運行結(jié)果。


所以要保證程序不出錯,當通過指針訪問變量的時候,要確保指針指向的地址是 4 字節(jié)對齊的,在 Keil 環(huán)境下,可以通過__attribute__((aligned (4))) 關(guān)鍵字實現(xiàn),如下圖所示,通過該關(guān)鍵字,對齊了地址,也就不會出現(xiàn) HardFault 異常了。


圖6 確保地址對齊


4.總結(jié)

地址未對齊是嵌入式系統(tǒng)中容易忽視的一個細節(jié),忽視這點往往會導致一些奇怪的問題,所以在開發(fā)過程中,注意這些細節(jié)還是很有必要的。



參考文獻:PM0223 Programming maual



長按掃碼關(guān)注公眾號


更多資訊,盡在STM32

點擊“閱讀原文”,可下載原文檔


原文標題:工程師筆記|一個地址未對齊引起的 HardFault 異常

文章出處:【微信公眾號:STM32單片機】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 單片機
    +關(guān)注

    關(guān)注

    6074

    文章

    45345

    瀏覽量

    663814
  • STM32
    +關(guān)注

    關(guān)注

    2305

    文章

    11123

    瀏覽量

    371211

原文標題:工程師筆記|一個地址未對齊引起的 HardFault 異常

文章出處:【微信號:STM32_STM8_MCU,微信公眾號:STM32單片機】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    招鑲?cè)胧?b class='flag-5'>工程師1,硬件工程師,

    東莞市研生科技有限公司是家藍牙方案公司,主營藍牙方案的設(shè)計開發(fā),產(chǎn)品包括藍牙BLE/4G透傳/AI智能體方案開發(fā),因公司發(fā)展需要需對外招聘嵌入式軟件開發(fā)工程師,對藍牙音頻/BLE以及智能IC讀卡器有三年實操經(jīng)驗,能單獨完成項目的軟件開發(fā),男女不限,投簡歷郵箱:65905
    發(fā)表于 08-29 02:14

    做了電子工程師之后,最好拍的視頻出現(xiàn)了#硬件設(shè)計 #電子DIY #電子工程師

    電子工程師
    安泰小課堂
    發(fā)布于 :2025年06月24日 17:45:57

    優(yōu)秀的射頻測試工程師需要具備哪些技能?

    優(yōu)秀的射頻測試工程師需要具備哪些技能?在無線技術(shù)高速發(fā)展的今天,射頻(RF)測試工程師是確保通信設(shè)備性能與用戶體驗的關(guān)鍵角色。從復雜的調(diào)制方案到無處不在的干擾,從功耗優(yōu)化到標準合規(guī)
    的頭像 發(fā)表于 05-16 10:08 ?1538次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>個</b>優(yōu)秀的射頻測試<b class='flag-5'>工程師</b>需要具備哪些技能?

    (仰天長嘯)為什么受傷的總是硬件工程師...#MDD#MDD辰達半導體 #電子工程師

    電子工程師
    MDD辰達半導體
    發(fā)布于 :2025年04月27日 18:21:47

    問,成為硬件工程師需要幾只手?#硬件工程師 #YXC晶振 #揚興科技 #搞笑

    硬件工程師
    揚興科技
    發(fā)布于 :2025年04月25日 17:15:37

    從“設(shè)計到生產(chǎn)”的蛻變:華秋DFM如何讓工程師們“輕松上陣”?

    在電子設(shè)計領(lǐng)域,工程師們常常面臨“隱形的敵人”: 設(shè)計與生產(chǎn)的脫節(jié) 。 比如精心設(shè)計的PCB,通過DRC檢查后,滿懷信心地送去生產(chǎn),結(jié)果仍被返工: 焊盤間距太小 ,無法保留阻焊及焊接飛料; 孔
    發(fā)表于 04-16 15:57

    硬件工程師:回答我!#回答我 #硬件工程師 #YXC晶振 #揚興科技

    硬件工程師
    揚興科技
    發(fā)布于 :2025年03月25日 18:46:59

    招拿捏電子工程師#被AI拿捏了 #電子工程師 #電子電工

    電子工程師
    安泰小課堂
    發(fā)布于 :2025年03月25日 17:30:51

    STM32H7 0x00000000地址的內(nèi)容引發(fā)hardfault怎么解決?

    函數(shù)時入?yún)?b class='flag-5'>異常,進入hardfault. 求助:關(guān)于stm32h7 ,0x00000000地址的內(nèi)容是如何被改變的?觀察過正常情況下的值,如下。前三
    發(fā)表于 03-07 08:15

    硬件工程師的終極幻想:焊板子焊上人生巔峰!#半導體器件 #硬件工程師 #MDD辰達半導體

    硬件工程師
    MDD辰達半導體
    發(fā)布于 :2025年02月24日 19:00:35

    笑死,掌握眼識別資深硬件工程師的訣竅了!# #電路知識 #電工 #硬核拆解

    硬件工程師
    MDD辰達半導體
    發(fā)布于 :2024年12月20日 17:48:17