• 正文
  • 推薦器件
  • 相關(guān)推薦
申請入駐 產(chǎn)業(yè)圖譜

又是編譯器的鍋?全局變量怎么就從棧里取數(shù)據(jù)了?!

2023/12/31
1389
加入交流群
掃碼加入
獲取工程師必備禮包
參與熱點資訊討論

來源:公眾號【魚鷹談單片機】,ID :emOsprey

一個學(xué)員項目上需要完成app升級功能,但是跳轉(zhuǎn)后直接 hardfault,項目緊急,只能找上魚鷹加急處理(課程福利)。

這種問題我都是比較自信的,M0+ 內(nèi)核,感覺問題不大,只是沒想到學(xué)員公司保密性比較強,不能遠程控制電腦,只能微信視頻進行指導(dǎo)調(diào)試,折騰許久,才最終定位跳轉(zhuǎn)地址出現(xiàn)問題。

static ?uint32_t jmp_app;

static uint32_t jmp_stack;

jmp_app = xx

jmp_stack = xxx

關(guān)閉中斷

__ISB();

__DMB();

設(shè)置中斷向量表

設(shè)置 msp 和 psp 棧

((void (*)(void))jmp_app)();

代碼類似如上,但是很奇怪的是,執(zhí)行最后一條代碼時,會從棧中取jmp_app的值(通過匯編分析),導(dǎo)致最終跳轉(zhuǎn)地址異常而hardfault,這個變量明明是靜態(tài)全局變量,而且同樣的代碼在stm32沒有問題。

全局變量數(shù)據(jù)從棧里面取,怎么都不符合常理,要么優(yōu)化后從寄存器取,要么從ram中取才對,沒聽說過要通過棧取數(shù)據(jù)(難道是前面設(shè)置棧的操作導(dǎo)致?)。

這個問題最終由學(xué)員發(fā)現(xiàn)是編譯器的鍋,用-O0 compiler6可以穩(wěn)定出錯,compile5沒問題,之前看一篇硬漢的文章說ac6在O0處理復(fù)雜宏時會產(chǎn)生大量的棧,O1沒問題,才知道編譯器也不可盡信,匯編也需要懂,否則出現(xiàn)類似問題根本無法解決,不知道各位道友是否有遇到類似問題。

推薦器件

更多器件
器件型號 數(shù)量 器件廠商 器件描述 數(shù)據(jù)手冊 ECAD模型 風(fēng)險等級 參考價格 更多信息
CSTNE8M00G55A000R0 1 Murata Manufacturing Co Ltd Ceramic Resonator,

ECAD模型

下載ECAD模型
$0.49 查看
S29JL032J70TFI313 1 Cypress Semiconductor Flash, 2MX16, 70ns, PDSO48, TSOP-48
$30.84 查看
AFBR-2644Z 1 Broadcom Limited Receiver, Through Hole Mount

ECAD模型

下載ECAD模型
$4.78 查看

相關(guān)推薦

登錄即可解鎖
  • 海量技術(shù)文章
  • 設(shè)計資源下載
  • 產(chǎn)業(yè)鏈客戶資源
  • 寫文章/發(fā)需求
立即登錄