在嵌入式應(yīng)用的開發(fā)過程中,雖然良好的編程實踐和配合適當(dāng)?shù)木幋a規(guī)范檢測軟件能夠減少代碼編寫階段中出現(xiàn)的錯誤數(shù)量,但仍然不可避免的會出現(xiàn)一些只有在程序運(yùn)行過程中才會觸發(fā)的錯誤。為了解決程序運(yùn)行過程中的問題,需要使用調(diào)試器,觀察代碼的執(zhí)行及軟件狀態(tài)變化。
在程序調(diào)試的過程中,斷點的重要性不言而喻。在調(diào)試狀態(tài)下,當(dāng)程序遇到斷點時,會停止執(zhí)行并將控制權(quán)交給調(diào)試軟件,調(diào)試器可以顯示當(dāng)前應(yīng)用程序的狀態(tài),包括變量和寄存器的值,內(nèi)存、堆棧使用情況,顯示應(yīng)用程序到達(dá)斷點位置的函數(shù)調(diào)用關(guān)系等,這些信息可以幫助開發(fā)人員分析程序的執(zhí)行狀況是否符合預(yù)期,并在問題出現(xiàn)時幫助確定錯誤原因。
常見的調(diào)試方法
(1)在RAM區(qū)域內(nèi)調(diào)試
在開發(fā)過程中,可以將應(yīng)用程序下載到RAM運(yùn)行和調(diào)試,調(diào)試器只需使用簡單的斷點指令,且RAM允許多次讀取和寫入,RAM區(qū)域內(nèi)的斷點指令不會對程序執(zhí)行產(chǎn)生明顯的影響。但該方法的局限是MCU所擁有的RAM空間通常較小,應(yīng)用較大時,無法在RAM進(jìn)行調(diào)試。
(2)在Flash區(qū)域內(nèi)調(diào)試
與RAM不同,F(xiàn)lash存儲空間通常較大,當(dāng)無法在RAM調(diào)試時只能在Flash區(qū)域內(nèi)進(jìn)行調(diào)試。微控制器設(shè)計人員提供了用于在Flash區(qū)域調(diào)試時使用的硬件斷點,硬件斷點會將PC指針與斷點位置進(jìn)行比較,并檢查指令是否被調(diào)用,當(dāng)斷點處指令被調(diào)用時,程序?qū)⑼V共诱{(diào)試器。硬件斷點的數(shù)量由芯片所使用的內(nèi)核決定,在ARM7和ARM9內(nèi)核中僅包含2個硬件斷點,在Cortex-M3和M4內(nèi)核中包含4-6個可用的硬件斷點。在調(diào)試過程中,當(dāng)硬件斷點數(shù)量用完時則無法添加新的斷點,只能取消前面添加的斷點后才能添加新的斷點,這無疑將嚴(yán)重影響程序開發(fā)效率。
(3)外擴(kuò)Flash存儲芯片調(diào)試
當(dāng)所開發(fā)的應(yīng)用程序的復(fù)雜度進(jìn)一步上升時,可能會使用到外擴(kuò)的Flash存儲,那么此時該如何進(jìn)行應(yīng)用程序調(diào)試呢?在大多數(shù)使用Cortex-M內(nèi)核的微控制器中,芯片內(nèi)部提供的硬件斷點在調(diào)試過程中能夠生效的地址范圍是有限的,當(dāng)使用外擴(kuò)Flash時,自帶的硬件斷點將無法在外擴(kuò)Flash存儲的地址范圍內(nèi)生效,此時將無法在這些區(qū)域內(nèi)設(shè)置斷點來調(diào)試應(yīng)用程序。
當(dāng)使用基于地址映射擴(kuò)展的外部Flash存儲時,Segger J-Link產(chǎn)品所支持的無限Flash斷點功能能夠幫助我們對片外Flash添加斷點并調(diào)試。
Segger無限Flash斷點功能
J-Link支持一項名為“無限Flash斷點”(Unlimited Flash Breakpoints)的調(diào)試功能。“無限Flash斷點”允許用戶在Flash中調(diào)試時設(shè)置無限數(shù)量的斷點。如果沒有此功能,在Flash中能夠設(shè)置的斷點數(shù)量限制為CPU調(diào)試單元支持的硬件斷點數(shù)。
J-Link的“無限Flash斷點”適用于片內(nèi)和外擴(kuò)的Flash,包括通過內(nèi)存映射添加的QSPI閃存。
無限Flash斷點的實現(xiàn)方式
Segger J-Link系列產(chǎn)品在實現(xiàn)無限Flash斷點功能時,會使用硬件和軟件斷點的混合,來盡可能的減少對于Flash的影響。當(dāng)硬件斷點數(shù)量用完再添加新斷點時,Segger軟件將對斷點所在位置的Flash區(qū)塊進(jìn)行重新編程來添加斷點。
雖然Flash存在一定的寫入次數(shù)限制,但Segger在實現(xiàn)該功能時已經(jīng)做了大量針對性的優(yōu)化來減少對于Flash的影響,例如處于同一區(qū)塊內(nèi)的多個斷點,Segger將通過一次該Flash區(qū)塊的重編編程來完成多個斷點的添加。Segger僅在必要時才會對Flash區(qū)塊進(jìn)行重編程,部分操作將通過內(nèi)置的指令集模擬器來完成,從而能夠盡可能的減少對于Flash閃存的影響。
Segger的無限Flash斷點調(diào)試功能解除了硬件斷點對于程序調(diào)試的限制,能夠提升開發(fā)人員的開發(fā)效率。對于Cortex-M內(nèi)核芯片添加了外擴(kuò)Flash的情形,無限Flash斷點功能則可能是僅有的片外Flash調(diào)試解決方案。
審核編輯 :李倩
-
FlaSh
+關(guān)注
關(guān)注
10文章
1657瀏覽量
150735 -
RAM
+關(guān)注
關(guān)注
8文章
1386瀏覽量
116515 -
斷點
+關(guān)注
關(guān)注
0文章
12瀏覽量
7845
原文標(biāo)題:如何使用J-Link無限Flash斷點功能調(diào)試應(yīng)用?
文章出處:【微信號:strongerHuang,微信公眾號:strongerHuang】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
SEGGER emFile支持大型數(shù)據(jù)庫
SEGGER SystemView支持Eclipse ThreadX

如何使用帶有i.MX 93處理器的Segger J-link在VSCode中進(jìn)行調(diào)試?
調(diào)試時Memory窗口中Flash內(nèi)容不更新的原因和解決辦法

Segger RTT調(diào)試工具的使用方法

基于SEGGER的Ozone調(diào)試器和J-Trace工具跟蹤Ferrocene的Rust應(yīng)用
HarmonyOS NEXT 原生應(yīng)用/元服務(wù)-ArkTS代碼調(diào)試worker/taskpool調(diào)試
前端調(diào)試實踐

HarmonyOS NEXT 原生應(yīng)用/元服務(wù)-ArkTS代碼調(diào)試使用斷點
SEGGER J-Link和Flasher工具支持意法半導(dǎo)體汽車微控制器
SEGGER SystemView支持多核行為的觀察和驗證

SEGGER為J-Link和Flasher提供Device Provisioner工具
網(wǎng)關(guān)斷點續(xù)傳可以實現(xiàn)什么功能
兆易創(chuàng)新和SEGGER探索MCU開發(fā)的無限可能
SEGGER編譯器優(yōu)化和安全技術(shù)介紹 支持最新C和C++語言

評論