Air780E/Air780EP/Air780EQ/Air201模塊遇到內(nèi)存死機如何分析
簡介
本文檔適用于合宙Air780E、Air780EP、Air780EQ、Air201
關(guān)聯(lián)文檔和使用工具:
移芯平臺模塊出現(xiàn)死機問題分析
EPAT抓取底層日志
從Ramdump里分析內(nèi)存泄漏問題
對于遇到內(nèi)存不足死機的問題,可以從ramdump里找出哪些函數(shù)在消耗ram。
進(jìn)入trace32后,在自動彈出下發(fā)圖片的窗口里能找到哪個函數(shù)在哪個task里用了多少ram沒有歸還,如果遇到哪個API大量申請了ram沒有歸還,基本上就是問題點了
為了查找方便,在trace_node選擇某個數(shù)據(jù),框里面右鍵 -> 點擊format
上圖里看到0x00868909 這個API在消耗大量的ram,從map文件,或者從trace_32工具菜單 view -> symbols -> browes 里搜索,Ctrl+F,或者Cov - > list functions,就能找到函數(shù)名稱。
這樣查找問題解答方向上 就相對明確了。
從Ramdump里分析棧溢出
需要檢查下trace32里有沒有freertos文件夾,如果沒有可以在這里下載放到根目錄freertos
一般來說,棧溢出會有斷言的情況,但是也有代碼申請了一大塊棧空間,導(dǎo)致棧底的ram沒有被改變,但是實際上代碼已經(jīng)操作了棧外空間,且freertos不會報錯,燃石在trace32里能分析出來。
打開trace32 -> freertos -> stack Coverage -> List Stacks
可以看到ram使用情況,注意這里認(rèn)為??臻g只有1KB,但是實際上可能是遠(yuǎn)超的,不過沒關(guān)系,如果max里是0%,說明還有很多??臻g,不用去管
Tmr Svc這個task居然用到了93%
右鍵點擊紅框,在彈出菜單里選擇display memory->dump
距離溢出只有不到70字節(jié),如果用戶代碼里有類似uint8_t temp[71],那么很容易就操作了棧外的ram,死機就很正常了
-
內(nèi)存
+關(guān)注
關(guān)注
8文章
3040瀏覽量
74167 -
死機
+關(guān)注
關(guān)注
0文章
17瀏覽量
8615 -
合宙通信
+關(guān)注
關(guān)注
0文章
148瀏覽量
1782
發(fā)布評論請先 登錄
相關(guān)推薦
評論