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

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

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

在MCU開(kāi)發(fā)中如何充分利用各種類型的斷點(diǎn)?

jf_pJlTbmA9 ? 來(lái)源:jf_pJlTbmA9 ? 作者:jf_pJlTbmA9 ? 2023-09-18 16:22 ? 次閱讀

在面向高可靠性應(yīng)用開(kāi)發(fā)MCU程序的過(guò)程中,工程師通常會(huì)遇到設(shè)定斷點(diǎn)的問(wèn)題,斷點(diǎn)的合理使用對(duì)于更好地編程和MCU使用是一種挑戰(zhàn)。借助新的工具,這些斷點(diǎn)就可以發(fā)揮巨大的作用,成為開(kāi)發(fā)工作中的利器。

斷點(diǎn)的概念非常簡(jiǎn)單,因?yàn)樗淖饔檬窃谥付ㄖ噶钪爸袛喑绦虻膱?zhí)行。實(shí)現(xiàn)方式可以是硬件或軟件。然而,簡(jiǎn)單并不意味著它不能被用于復(fù)雜的調(diào)試組合中,以達(dá)到用簡(jiǎn)單的方式解決BUG的目的。事實(shí)上,軟件開(kāi)發(fā)者在調(diào)試時(shí)離不開(kāi)斷點(diǎn),但如何最好地利用斷點(diǎn)呢?

要更好地使用各種斷點(diǎn),開(kāi)發(fā)人員不能僅靠經(jīng)驗(yàn)或者直覺(jué),需要借助一些先進(jìn)的開(kāi)發(fā)工具來(lái)完成,它們可以幫助開(kāi)發(fā)人員去了解不同斷點(diǎn)的特點(diǎn)和價(jià)值。例如,在IAR Embedded Workbench工具中,開(kāi)發(fā)人員可以使用以下斷點(diǎn):

代碼斷點(diǎn)

條件代碼斷點(diǎn)

具有讀寫訪問(wèn)的數(shù)據(jù)斷點(diǎn)

數(shù)據(jù)日志斷點(diǎn)

日志斷點(diǎn)

功率斷點(diǎn)

Trace開(kāi)始和停止斷點(diǎn)

本文將指導(dǎo)開(kāi)發(fā)人員如何利用每一個(gè)可用的斷點(diǎn)來(lái)更快地調(diào)試程序。

代碼斷點(diǎn)

代碼斷點(diǎn)是最簡(jiǎn)單的斷點(diǎn)。開(kāi)發(fā)人員只需要選擇C代碼或者反匯編窗口中的ASM指令并設(shè)置斷點(diǎn)即可。一旦斷點(diǎn)被觸發(fā),程序就會(huì)暫停。此時(shí),開(kāi)發(fā)人員就可以檢查變量、標(biāo)志和寄存器的值。換句話說(shuō),開(kāi)發(fā)人員現(xiàn)在擁有了完全控制權(quán)限。

wKgaomUD9VCAXc48AAa_3m65sX4725.png

代碼斷點(diǎn)的數(shù)量受限于MCU硬件斷點(diǎn)的數(shù)量,但如果代碼在RAM中運(yùn)行,開(kāi)發(fā)人員利用軟件斷點(diǎn),軟件斷點(diǎn)的數(shù)量則可以是無(wú)限的。即使數(shù)量有限,例如對(duì)于Arm Cortex-M,有6到8個(gè)斷點(diǎn),但開(kāi)發(fā)人員也可以保存斷點(diǎn)位置并在需要時(shí)禁用和啟用斷點(diǎn)。只需要選擇顯示View ->Breakpoints window,就可以選中/清除方框,也就是啟用或禁用斷點(diǎn)。

wKgZomUD9VOAKOgbAAWffjG9OAs877.png

在這種情況下,可以有6到8個(gè)以上的斷點(diǎn),但不能同時(shí)都激活。

默認(rèn)情況下,IDE會(huì)設(shè)置代碼斷點(diǎn)。如果開(kāi)發(fā)人員有一個(gè)I-jet仿真器,就可以在右鍵點(diǎn)擊代碼行時(shí)明確地選擇一個(gè)flash斷點(diǎn)。如果開(kāi)發(fā)人員已經(jīng)用完了現(xiàn)有全部硬件斷點(diǎn),這招會(huì)很有用。注意斷點(diǎn)符號(hào)中的“F”說(shuō)明改斷點(diǎn)是Flash斷點(diǎn)。IAR Embedded Workbench for Arm的7.60或更高版本中提供flash斷點(diǎn)功能。

wKgaomUD9VWAP_7hAAYMynDgWWc676.png

條件代碼斷點(diǎn)

條件斷點(diǎn)是代碼斷點(diǎn)與一些標(biāo)志或變量(作為條件)的組合。設(shè)置好斷點(diǎn)后,開(kāi)發(fā)人員可以再次使用View->Breakpoints window來(lái)查看所有斷點(diǎn),也可以通過(guò)右鍵點(diǎn)擊并選擇Edit option來(lái)設(shè)置額外參數(shù)。

wKgZomUD9VeAWjD9AAVvmGyB6RM521.png

使用的語(yǔ)法類似于C語(yǔ)言的語(yǔ)法,包括==、>=和<=。例如,如果想讓應(yīng)用在計(jì)數(shù)器等于10的時(shí)候停止在斷點(diǎn),則可以使用“counter==10”。

wKgaomUD9VqAO040AAIvXXNsyDA536.png

當(dāng)需要在一個(gè)中斷例程內(nèi)設(shè)置斷點(diǎn)時(shí),這非常有用。如果沒(méi)有條件,就不可能調(diào)試應(yīng)用,因?yàn)槌绦驅(qū)⒁恢蓖V埂J褂脴?biāo)志或變量作為條件可以簡(jiǎn)化操作。此外,還可以進(jìn)一步使用跳過(guò)計(jì)數(shù)器和條件檢查,如true或changed。

具有讀寫訪問(wèn)的數(shù)據(jù)斷點(diǎn)

相比其他斷點(diǎn),數(shù)據(jù)斷點(diǎn)有些不同,因?yàn)樗鼈儽O(jiān)測(cè)對(duì)特定內(nèi)存地址、標(biāo)志、變量或寄存器的讀寫訪問(wèn)。數(shù)據(jù)斷點(diǎn)使用非常直截了當(dāng)只需右鍵點(diǎn)擊標(biāo)志或變量,然后選擇選項(xiàng)Set dataBreakpoint即可。默認(rèn)情況下,讀和寫的訪問(wèn)將被監(jiān)測(cè)。如果開(kāi)發(fā)人員想增加額外的設(shè)置,可以通過(guò)View->Breakpoints window和Edit option來(lái)完成。除了訪問(wèn)之外,還可以監(jiān)測(cè)數(shù)據(jù)是否匹配。這意味著只有當(dāng)數(shù)據(jù)匹配時(shí),寫或讀的訪問(wèn)才會(huì)觸發(fā)停止。選擇“Edit”按鈕,可以打開(kāi)一個(gè)額外的窗口,可以選擇絕對(duì)地址甚至是源代碼行。如果是一個(gè)變量或標(biāo)志,建議使用自動(dòng)大小。如果需要監(jiān)測(cè)更大的范圍,應(yīng)手動(dòng)設(shè)置所需的大小。

wKgaomUD9VyAU5bHAAHfpsKlWps037.png

數(shù)據(jù)斷點(diǎn)對(duì)于調(diào)試被應(yīng)用破壞的標(biāo)志和變量非常有用。一旦出現(xiàn)了讀寫訪問(wèn),應(yīng)用就會(huì)停止。另一種用法是堆棧溢出調(diào)查,只需要在堆棧大小的80-90%處設(shè)置一個(gè)數(shù)據(jù)斷點(diǎn),當(dāng)溢出接近時(shí),就可以停止應(yīng)用,并一步步找到問(wèn)題的根源。

數(shù)據(jù)日志斷點(diǎn)

除了可監(jiān)測(cè)讀寫訪問(wèn)的數(shù)據(jù)斷點(diǎn)外,開(kāi)發(fā)人員還可以使用數(shù)據(jù)日志斷點(diǎn)。使用這些斷點(diǎn)的目的是監(jiān)測(cè)并以圖形方式繪制特定變量或內(nèi)存地址的值跟隨時(shí)間的變化,這就能更輕松地比較多個(gè)變量,觀察中斷觸發(fā)的情況。

wKgZomUD9V2AHLnrAAV_angN-5I587.png

仿真器選項(xiàng)提供了時(shí)間軸、附加數(shù)據(jù)日志和數(shù)據(jù)日志總結(jié),如下圖所示。

wKgaomUD9V-AZiYgAAYyA5osI7Q827.png

日志斷點(diǎn)

除了代碼斷點(diǎn)和數(shù)據(jù)斷點(diǎn)之外,開(kāi)發(fā)人員還可以使用日志斷點(diǎn)。這是一個(gè)特殊的斷點(diǎn),因?yàn)樗粫?huì)暫時(shí)停止應(yīng)用來(lái)打印一條信息。只有當(dāng)斷點(diǎn)被觸發(fā)時(shí),它才會(huì)顯示選定的信息。

wKgaomUD9WCASNR7AAFDr06vm2s846.png

每當(dāng)斷點(diǎn)被觸發(fā),一條信息就會(huì)顯示在調(diào)試日志窗口中。配合計(jì)數(shù)器,我們就可以知道應(yīng)用源代碼的特定部分運(yùn)行了多少次。

wKgZomUD9WKAaQ_YAAUq-rA2vRE867.png

功率斷點(diǎn)

得益于IAR Embedded Workbench的功率調(diào)試技術(shù),開(kāi)發(fā)人員可以監(jiān)控能耗并將其與源代碼聯(lián)系起來(lái)。這使得了解整個(gè)應(yīng)用的能耗成為可能。這個(gè)概念也使得添加功率斷點(diǎn)成為可能??梢栽O(shè)置一個(gè)閾值,比如25mA,一旦能耗超過(guò)這個(gè)值,調(diào)試器就會(huì)中斷。

wKgZomUD9WSANrKyAATlnlA3FZ0937.png

設(shè)置閾值的操作非常簡(jiǎn)單。只需要打開(kāi)I-jet -> PowerLog window,然后設(shè)置數(shù)值和對(duì)應(yīng)的操作。

wKgaomUD9WaAC2ioAAWN80pLyo4770.png

這個(gè)功能很有用,可以保證不出現(xiàn)任何耗電浪涌或高于指定值的情況,而且通過(guò)這種分析,電池的使用壽命也會(huì)延長(zhǎng),開(kāi)發(fā)人員可以放心讓其應(yīng)用長(zhǎng)時(shí)間運(yùn)行。雖然時(shí)間軸窗口不是必須的,但它能提供實(shí)時(shí)的能耗信息。

Trace開(kāi)始和停止斷點(diǎn)

最后要介紹的是Trace開(kāi)始和停止斷點(diǎn)。如果開(kāi)發(fā)人員使用先進(jìn)的仿真器,比如I-jet Trace for Arm Cortex-M或I-jet Trace for Cortex-A/R/M,就可以利用這些斷點(diǎn)。這在分析應(yīng)用特定部分時(shí)特別有用。Trace開(kāi)始和Trace停止斷點(diǎn)簡(jiǎn)單易用,只需在代碼行中右鍵點(diǎn)擊并決定跟蹤的開(kāi)始和結(jié)束位置即可。Trace緩沖區(qū)將只保存應(yīng)用中指定代碼行之間的指令。

wKgZomUD9WiAf7EwAAXp76wa7p4056.png

另外,開(kāi)發(fā)人員也可以從時(shí)間軸上的Trace指令中得到函數(shù)調(diào)用的圖形概覽,這些函數(shù)調(diào)用信息是在Trace開(kāi)始和停止斷點(diǎn)之間捕獲的。

wKgaomUD9WmARwfYAAS7-b5SXOg351.png

雖然I-jet Trace仿真器比標(biāo)準(zhǔn)JTAG/SWD仿真器更強(qiáng)大,但有時(shí)如果記錄包含所有正常信息時(shí),Trace調(diào)試變得很麻煩。為了避免收集數(shù)以百萬(wàn)計(jì)的非必要指令,使Trace調(diào)試變得簡(jiǎn)單明了,IAR Embedded Workbench提供了Trace開(kāi)始和停止斷點(diǎn)的功能。

審核編輯:彭菁

聲明:本文內(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

    文章

    16796

    瀏覽量

    349332
  • 數(shù)據(jù)
    +關(guān)注

    關(guān)注

    8

    文章

    6754

    瀏覽量

    88613
  • 編程
    +關(guān)注

    關(guān)注

    88

    文章

    3543

    瀏覽量

    93466
  • 程序
    +關(guān)注

    關(guān)注

    115

    文章

    3743

    瀏覽量

    80661
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    如何充分利用各種類型斷點(diǎn)

    代碼斷點(diǎn)是最簡(jiǎn)單的斷點(diǎn)開(kāi)發(fā)人員只需要選擇C代碼或者反匯編窗口中的ASM指令并設(shè)置斷點(diǎn)即可。一旦斷點(diǎn)被觸發(fā),程序就會(huì)暫停。
    發(fā)表于 09-18 11:03 ?1548次閱讀
    如何<b class='flag-5'>充分利用</b><b class='flag-5'>各種類型</b>的<b class='flag-5'>斷點(diǎn)</b>

    讓你的內(nèi)存每秒都能充分利用:內(nèi)存釋放專家

    讓你的內(nèi)存每秒都能充分利用:內(nèi)存釋放專家
    發(fā)表于 06-01 18:45

    如何充分利用光纖配線箱?

    ,光纖配線箱為各種應(yīng)用提供了更豐富的功能和更靈活的布線環(huán)境。選擇正確的光纖配線箱,充分利用光纖配線箱至關(guān)重要。下面我將告訴大家如何在數(shù)據(jù)中心里充分利用光纖配線箱,使布線環(huán)境更為靈活。靈活布線
    發(fā)表于 09-13 15:59

    如何充分利用這些頻譜資源

    之前的文章(《如何實(shí)現(xiàn)比4G快十倍?毫米波技術(shù)是5G的關(guān)鍵》)我們介紹了如何利用毫米波技術(shù)獲得更多的頻譜資源,接下來(lái)的問(wèn)題是如何充分利用這些頻譜資源——如何讓多個(gè)用戶通訊但又互不干
    發(fā)表于 07-11 07:09

    XC7K325T FPGA如何充分利用GTX資源?

    嗨,我需要在XC7K325T FPGA充分利用GTX資源。結(jié)果,我必須以這種方式使用一個(gè)四邊形,它的兩個(gè)頻道應(yīng)該服務(wù)于10Gb / s鏈路和另外兩個(gè)--1Gb / s鏈路。這意味著,兩個(gè)通道必須
    發(fā)表于 07-22 13:25

    開(kāi)關(guān)電源轉(zhuǎn)換器如何充分利用SiC器件的性能優(yōu)勢(shì)?

    開(kāi)關(guān)電源轉(zhuǎn)換器,如何充分利用SiC器件的性能優(yōu)勢(shì)?
    發(fā)表于 02-22 07:16

    如何充分利用電子設(shè)計(jì)工具呢

    電子設(shè)計(jì)人員使用的工具箱日新月異。要找到適合工作的工具,不僅需要了解手頭上的任務(wù)和現(xiàn)有工具,還要知道如何充分利用這些工具。對(duì)于設(shè)計(jì)人員來(lái)說(shuō),隔離柵內(nèi)移動(dòng)信號(hào)和電源是一項(xiàng)常見(jiàn)的挑戰(zhàn)。為了提高
    發(fā)表于 12-31 06:42

    各種類型電容器的比較

    各種類型電容器的比較 頻率的特性
    發(fā)表于 02-10 11:49 ?1046次閱讀
    <b class='flag-5'>各種類型</b>電容器的比較

    并行編程無(wú)進(jìn)展使多核芯片未能充分利用

    并行編程無(wú)進(jìn)展使多核芯片未能充分利用 《福布斯》文章指出,為什么應(yīng)用軟件總是無(wú)法充分利用芯片的強(qiáng)大功能呢?如何充分有效地利用
    發(fā)表于 04-01 16:43 ?712次閱讀

    充分利用超級(jí)大寫電腦

    充分利用超級(jí)大寫電腦
    發(fā)表于 05-21 19:04 ?0次下載
    <b class='flag-5'>充分利用</b>超級(jí)大寫電腦

    方舟開(kāi)發(fā)框架容器類的各種類型

    屬性的限制,讓每種類型的數(shù)據(jù)都能在完成自身功能的基礎(chǔ)上剪除冗余分支,保證了數(shù)據(jù)的高效訪問(wèn),提升了應(yīng)用的性能。本期,我們將為大家介紹方舟開(kāi)發(fā)框架容器類的各種類型以及相關(guān)API的使用。
    的頭像 發(fā)表于 03-14 13:45 ?1492次閱讀
    方舟<b class='flag-5'>開(kāi)發(fā)</b>框架<b class='flag-5'>中</b>容器類的<b class='flag-5'>各種類型</b>

    各種類型的混頻器及優(yōu)缺點(diǎn)

    RF和微波設(shè)計(jì),混頻是信號(hào)鏈最關(guān)鍵的部分之一。今天我們就講講各種類型的混頻器以及各自的優(yōu)缺點(diǎn)。
    的頭像 發(fā)表于 10-19 10:26 ?6218次閱讀

    充分利用電位計(jì) — 別讓旋轉(zhuǎn)亂套!

    充分利用電位計(jì) — 別讓旋轉(zhuǎn)亂套!
    發(fā)表于 11-07 08:07 ?0次下載
    <b class='flag-5'>充分利用</b>電位計(jì) — 別讓旋轉(zhuǎn)亂套!

    如何充分利用各種類型斷點(diǎn)

    面向高可靠性應(yīng)用開(kāi)發(fā)MCU程序的過(guò)程,工程師通常會(huì)遇到設(shè)定斷點(diǎn)的問(wèn)題,斷點(diǎn)的合理使用對(duì)于更好
    的頭像 發(fā)表于 07-24 14:29 ?492次閱讀
    如何<b class='flag-5'>充分利用</b><b class='flag-5'>各種類型</b>的<b class='flag-5'>斷點(diǎn)</b>

    如何充分利用單片機(jī)(MCU)的非易失性存儲(chǔ)器呢?

    如何充分利用單片機(jī)(MCU)的非易失性存儲(chǔ)器 單片機(jī)(MCU)的非易失性存儲(chǔ)器(NVM)是存儲(chǔ)數(shù)據(jù)和程序的重要組成部分。它可以保留數(shù)據(jù),即使斷電或復(fù)位后也不會(huì)丟失。為了
    的頭像 發(fā)表于 12-15 10:10 ?1055次閱讀