RM新时代网站-首页

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

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

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

不復(fù)位MCU繼續(xù)調(diào)試的方法

STM32單片機(jī) ? 來(lái)源:STM32單片機(jī) ? 2024-01-26 09:25 ? 次閱讀

01前言

產(chǎn)品開(kāi)發(fā)時(shí),經(jīng)常會(huì)碰到在測(cè)試過(guò)程中或設(shè)備出廠后才發(fā)現(xiàn)程序異常,但當(dāng)重新對(duì)設(shè)備仿真調(diào)試時(shí)卻復(fù)現(xiàn)不出現(xiàn)場(chǎng)的問(wèn)題,或者只通過(guò)保存的日志信息艱難分析代碼運(yùn)行到了何處而導(dǎo)致的異常。

遇到這種場(chǎng)景,也并非無(wú)路可循。原則上只要我們通過(guò)仿真器調(diào)試時(shí),做到代碼不被重新下載覆蓋,MCU 不被復(fù)位,就可能保留當(dāng)前程序運(yùn)行的狀態(tài),讓 Bug 無(wú)處藏身。

02實(shí)現(xiàn)方法

首先,我們將編譯完成的工程燒錄到 MCU,保證 MCU 中所運(yùn)行的代碼與要仿真的工程代碼一致,這樣從 MCU 獲取的程序位置才能與調(diào)試符號(hào)信息一致。

不同的編譯器可以通過(guò)不同的方法進(jìn)行設(shè)置,但其目的和最終能達(dá)到的效果是一致的。我們就對(duì)常用的 MDK、IAR、STM32CubeIDE 三種不同編譯器分別進(jìn)行設(shè)置,使 MCU 在不復(fù)位的狀態(tài)下繼續(xù)調(diào)試。

03MDK

1. 新建一個(gè).ini 文件,在文件中寫入以下內(nèi)容:LOAD %L INCREMENTAL,并加載到Initialization File,同時(shí)取消 Load Application at Startup 的選項(xiàng)。

8bd718d0-bb67-11ee-8b88-92fbcf53809c.jpg

8bec1ce4-bb67-11ee-8b88-92fbcf53809c.jpg

這個(gè)腳本的目的是加載編譯生成的.axf 文件到 MDK 中,該文件包含 bin 代碼和調(diào)試相關(guān)的各種符號(hào)信息,以定位我們的 C 源碼。

關(guān)于其語(yǔ)法說(shuō)明,可參考 MDK 的 uVision User’s Guide。

8bf3991a-bb67-11ee-8b88-92fbcf53809c.jpg

2. 去掉 Reset after Connect 選項(xiàng)

8bfee34c-bb67-11ee-8b88-92fbcf53809c.jpg

3. 去掉 Update Target before Debugging

8c0a0902-bb67-11ee-8b88-92fbcf53809c.jpg

4. 完成上述配置后,就可以在 MCU 不復(fù)位的情況下,像正常調(diào)試一樣加斷點(diǎn)調(diào)試了。

04IAR

使用 IAR 時(shí),無(wú)需額外設(shè)置,直接使用其自帶的功能“Attach to Running Target”即可實(shí)現(xiàn)。

8c1d226c-bb67-11ee-8b88-92fbcf53809c.jpg

05STM32CubeIDE

在 STM32CubeIDE 中,配置比較靈活,可以復(fù)制一個(gè) Debug 的配置,并在這個(gè)基礎(chǔ)上進(jìn)行修改。

8c302984-bb67-11ee-8b88-92fbcf53809c.jpg

1. 配置 Debugger->Reset behaviour Type 為 None

8c3b3130-bb67-11ee-8b88-92fbcf53809c.jpg

2. 在 Debugger->Misc 中取消 Verify flash download 選項(xiàng)

8c4ff7aa-bb67-11ee-8b88-92fbcf53809c.jpg

3. 在 Startup->Load Image and Symbols 中編輯下載代碼時(shí)的操做方式。并取消Download 選項(xiàng)

8c5ab96a-bb67-11ee-8b88-92fbcf53809c.jpg

8c6e6ae6-bb67-11ee-8b88-92fbcf53809c.jpg

4. 在 Debug 時(shí),用上述配置完的調(diào)試配置,即可同樣實(shí)現(xiàn)不復(fù)位的調(diào)試

8c7ec260-bb67-11ee-8b88-92fbcf53809c.jpg

06總結(jié)

利用上述不復(fù)位 MCU 繼續(xù)調(diào)試的方法,能夠保全現(xiàn)場(chǎng)的運(yùn)行狀態(tài),重新接上仿真器即可對(duì)程序進(jìn)行斷點(diǎn)調(diào)試、單步執(zhí)行等操作。對(duì)查找 Bug,發(fā)現(xiàn)并定位問(wèn)題點(diǎn),尤其對(duì)不易復(fù)現(xiàn)的偶發(fā)性故障十分有用。但是當(dāng) RDP Level≠0 時(shí),因?yàn)橐呀?jīng)開(kāi)啟了讀保護(hù),所以無(wú)法通過(guò)上述方法調(diào)試。

審核編輯:湯梓紅

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

    關(guān)注

    146

    文章

    17123

    瀏覽量

    350978
  • 調(diào)試
    +關(guān)注

    關(guān)注

    7

    文章

    578

    瀏覽量

    33923
  • 編譯器
    +關(guān)注

    關(guān)注

    1

    文章

    1623

    瀏覽量

    49108
  • 燒錄
    +關(guān)注

    關(guān)注

    8

    文章

    259

    瀏覽量

    35561

原文標(biāo)題:實(shí)戰(zhàn)經(jīng)驗(yàn) | 調(diào)試小技巧之不復(fù)位調(diào)試

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

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    請(qǐng)問(wèn)stm8l101p3u為什么進(jìn)入halt之后看門狗不復(fù)位?

    在網(wǎng)上查了半天,很多人都是說(shuō)halt之后不想讓看門狗運(yùn)行卻停不下來(lái),為什么到了我這我想halt之后看門狗繼續(xù)運(yùn)行它反而不復(fù)位了呢?? 看門狗的代碼 RST_ClearFlag
    發(fā)表于 05-13 07:01

    cc2650 OAD結(jié)束后不復(fù)位,為什么?

    Device Monitor的OAD功能,看上去可以向cc2650傳輸OADbin.bin,但OAD結(jié)束后,cc2650不復(fù)位;3.在1基礎(chǔ)上,調(diào)試OADTarget工程的CC2640App
    發(fā)表于 03-28 16:17

    請(qǐng)問(wèn)28033有可能出現(xiàn)死機(jī)但是不復(fù)位的情況嗎?

    鄙人做的是開(kāi)關(guān)電源,在最惡劣工況加載時(shí),DSP什么反應(yīng)都沒(méi)有,也不復(fù)位,系統(tǒng)成了一塊磚,我之前的類似工況,DSP都是***擾的復(fù)位的,這次怎么不復(fù)位也不工作呢?有達(dá)人指點(diǎn)一下嗎?
    發(fā)表于 10-08 16:55

    IDE設(shè)置步驟有哪些

    使用場(chǎng)景:當(dāng)MCU運(yùn)行時(shí)出現(xiàn)Bug,但沒(méi)有在線調(diào)試;此時(shí)可以使用該方法,在不復(fù)位的情形下捕捉代碼當(dāng)前運(yùn)行到的位置,繼續(xù)在線
    發(fā)表于 11-01 07:09

    IAR調(diào)試中不同復(fù)位類型的介紹

    IAR調(diào)試中不同復(fù)位類型的介紹在IAR 環(huán)境下調(diào)試有不同的復(fù)位類型,其中一些只復(fù)位內(nèi)核不復(fù)位
    發(fā)表于 10-19 07:54

    IAR退出調(diào)試時(shí)如何讓MCU繼續(xù)運(yùn)行?

    RT,每次退出調(diào)試要給板子重新上電MCU才運(yùn)行,如何在退出時(shí)繼續(xù)運(yùn)行?
    發(fā)表于 10-20 06:53

    哪些因素會(huì)導(dǎo)致MCU復(fù)位

    調(diào)試MCU時(shí),經(jīng)常會(huì)遇到復(fù)位的情況。要找到復(fù)位的原因,我們就需要了解到有哪些因素會(huì)導(dǎo)致MCU復(fù)位
    的頭像 發(fā)表于 11-10 16:32 ?1w次閱讀
    哪些因素會(huì)導(dǎo)致<b class='flag-5'>MCU</b><b class='flag-5'>復(fù)位</b>

    華大MCU如何實(shí)現(xiàn)軟件復(fù)位

    產(chǎn)品在設(shè)計(jì)中某些狀態(tài)下需要MCU進(jìn)行復(fù)位,華大MCU包含了7個(gè)復(fù)位信號(hào)來(lái)源,每個(gè)復(fù)位信號(hào)都可以讓 CPU 重新運(yùn)行,絕大多數(shù)寄存器會(huì)被
    發(fā)表于 10-12 11:24 ?1973次閱讀

    KEIL/MDK中使用JLINK調(diào)試器掛載正在運(yùn)行中的MCU

    使用場(chǎng)景:當(dāng)MCU運(yùn)行時(shí)出現(xiàn)Bug,但沒(méi)有在線調(diào)試;此時(shí)可以使用該方法,在不復(fù)位的情形下捕捉代碼當(dāng)前運(yùn)行到的位置,繼續(xù)在線
    發(fā)表于 10-25 18:36 ?13次下載
    KEIL/MDK中使用JLINK<b class='flag-5'>調(diào)試</b>器掛載正在運(yùn)行中的<b class='flag-5'>MCU</b>

    初始化mcu程序選用32k_MCU有多少種復(fù)位因素

    調(diào)試MCU時(shí),經(jīng)常會(huì)遇到復(fù)位的情況。要找到復(fù)位的原因,我們就需要了解到有哪些因素會(huì)導(dǎo)致MCU復(fù)位
    發(fā)表于 12-05 10:36 ?6次下載
    初始化<b class='flag-5'>mcu</b>程序選用32k_<b class='flag-5'>MCU</b>有多少種<b class='flag-5'>復(fù)位</b>因素

    不復(fù)位MCU直接調(diào)試運(yùn)行程序

    此時(shí)此刻有一種調(diào)試需求是朋友們非常想要的:一旦程序出了問(wèn)題,我只需要插上仿真器,目標(biāo)硬件不會(huì)復(fù)位,而是與我當(dāng)前所調(diào)試的程序同步,類似于仿真程序的時(shí)候的“全速運(yùn)行”,然而通過(guò)添加斷點(diǎn),便可查看程序具體的運(yùn)行狀態(tài),內(nèi)存等等信息,讓b
    的頭像 發(fā)表于 05-12 15:43 ?1349次閱讀

    MCU復(fù)位電路知多少?

    MCU復(fù)位電路知多少?
    的頭像 發(fā)表于 10-17 18:02 ?1211次閱讀
    <b class='flag-5'>MCU</b><b class='flag-5'>復(fù)位</b>電路知多少?

    如何排查GD32 MCU復(fù)位是由哪個(gè)復(fù)位源導(dǎo)致的?

    上期為大家講解了GD32 MCU復(fù)位包括電源復(fù)位和系統(tǒng)復(fù)位,其中系統(tǒng)復(fù)位還包括獨(dú)立看門狗復(fù)位、內(nèi)
    的頭像 發(fā)表于 02-03 09:46 ?1727次閱讀
    如何排查GD32 <b class='flag-5'>MCU</b><b class='flag-5'>復(fù)位</b>是由哪個(gè)<b class='flag-5'>復(fù)位</b>源導(dǎo)致的?

    MCU不復(fù)位調(diào)試的小技巧

    場(chǎng)景,也并非無(wú)路可循。原則上只要我們通過(guò)仿真器調(diào)試時(shí),做到代碼不被重新下載覆蓋,MCU 不被復(fù)位,就可能保留當(dāng)前程序運(yùn)行的狀態(tài),讓 Bug 無(wú)處藏身。 02 實(shí)現(xiàn)方法 首先,我們將編譯
    發(fā)表于 02-26 11:30 ?1164次閱讀
    <b class='flag-5'>MCU</b><b class='flag-5'>不復(fù)位</b><b class='flag-5'>調(diào)試</b>的小技巧

    MCU復(fù)位RAM會(huì)保持嗎,如何實(shí)現(xiàn)復(fù)位時(shí)變量數(shù)據(jù)保持

    在使用MCU時(shí),通常大家默認(rèn)MCU復(fù)位時(shí)RAM會(huì)被復(fù)位清零,那實(shí)際MCU復(fù)位時(shí)RAM是什么狀態(tài)?
    的頭像 發(fā)表于 03-01 09:32 ?2473次閱讀
    <b class='flag-5'>MCU</b><b class='flag-5'>復(fù)位</b>RAM會(huì)保持嗎,如何實(shí)現(xiàn)<b class='flag-5'>復(fù)位</b>時(shí)變量數(shù)據(jù)保持
    RM新时代网站-首页