<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > 使用RealView MDK進(jìn)行SW調試和實(shí)時(shí)跟蹤

使用RealView MDK進(jìn)行SW調試和實(shí)時(shí)跟蹤

作者: 時(shí)間:2011-11-03 來(lái)源:網(wǎng)絡(luò ) 收藏

一、目標調試階段的配置

1. 調試器的選擇

選擇μVision->Debug ->Options for Target –>Debug,并選擇ULINK Cortex Debugger調試器。

使用RealView MDK進(jìn)行SW調試和實(shí)時(shí)跟蹤

2. 調試目標初始化文件

按照路徑KeilARMStartupST,將文件STM32DBG.ini拷貝到工程文件夾中。選擇μVision->Debug -> Options for Target –>Debug,同時(shí)在Initialization File選項中選擇該文件。

使用RealView MDK進(jìn)行SW調試和實(shí)時(shí)跟蹤

3. Cortex-M 目標設備調試驅動(dòng)配置

選擇Options for Target – Debug – Settings,設置SWJ,端口選擇SW。

使用RealView MDK進(jìn)行SW調試和實(shí)時(shí)跟蹤

4. Trace功能的配置

Trace功能包括:Core Clock, Trace Port 以及定義TraceEvents 等。

使用RealView MDK進(jìn)行SW調試和實(shí)時(shí)跟蹤

二、

1. μVision的狀態(tài)欄信息

在μVision的狀態(tài)欄中顯示了的狀態(tài)信息。

使用RealView MDK進(jìn)行SW調試和實(shí)時(shí)跟蹤

2. 窗口

調試時(shí)選擇Peripherals – Trace。

使用RealView MDK進(jìn)行SW調試和實(shí)時(shí)跟蹤

1) Trace Records窗口

該窗口顯示了所有被捕獲的跟蹤記錄,每一個(gè)跟蹤記錄都包含了詳細的信息??梢赃x擇Peripherals - Trace – Records來(lái)查看。

使用RealView MDK進(jìn)行SW調試和實(shí)時(shí)跟蹤

2) Exception Trace 窗口

該窗口顯示了異常和中斷的統計信息,這些信息是基于Trace Records中所捕獲的跟蹤記錄的??梢赃x擇Peripherals - Trace - Exceptions來(lái)查看。

使用RealView MDK進(jìn)行SW調試和實(shí)時(shí)跟蹤

3) Event Counters窗口

這個(gè)窗口顯示了特殊事件計數器的值,計數值是基于Trace Records中所捕獲的跟蹤記錄的。

使用RealView MDK進(jìn)行SW調試和實(shí)時(shí)跟蹤

3. ITM Viewer窗口

可以通過(guò)ITM的激勵端口0在ITM Viewer窗口上輸出ASCII 或 Hex格式的數據,目前只有ITM 端口0可以在ITM Viewer窗口顯示。要使用ITM Viewer窗口來(lái)顯示調試跟蹤的輸出信息,需要進(jìn)行以下的操作。

l 在源代碼中添加ITM激勵端口寄存器的定義。

#define ITM_Port8(n) (*((volatile unsigned char *)(0xE0000000+4*n)))

#define ITM_Port16(n) (*((volatile unsigned short*)(0xE0000000+4*n)))

#define ITM_Port32(n) (*((volatile unsigned long *)(0xE0000000+4*n)))

#define DEMCR (*((volatile unsigned long *)(0xE000EDFC)))

#define TRCENA 0x01000000

l 在源代碼中添加fputc函數,它向ITM的激勵端口0寄存器寫(xiě)數據。如果有了fputc函數,則可以用printf函數做為調試輸出。ITM的激勵端口0與ITM Viewer窗口固定連接。

struct __FILE { int handle; /* Add whatever you need here */ };

FILE __stdout;

FILE __stdin;

int fputc(int ch, FILE *f) {

if (DEMCR  TRCENA) {

while (ITM_Port32(0) == 0);

ITM_Port8(0) = ch;

 }

return(ch);

}

l 在源代碼中添加printf函數來(lái)顯示調試跟蹤信息。

printf("Serial Wire Output Debug Trace message"); 

l 在Cortex-M Target Driver Setup窗口中使能ITM激勵端口0

使用RealView MDK進(jìn)行SW調試和實(shí)時(shí)跟蹤

l 在目標調試期,打開(kāi)ITM Viewer窗口

選擇μVision-> View -> Serial Window -> ITM Viewer

使用RealView MDK進(jìn)行SW調試和實(shí)時(shí)跟蹤

完成這些步驟以后,可以在目標調試期通過(guò)ITM Viewer窗口查看到調試跟蹤信息,例如顯示AD轉換的結果。

使用RealView MDK進(jìn)行SW調試和實(shí)時(shí)跟蹤

ITM Viewer的功能類(lèi)似串口打印調試信息,使用ITM更簡(jiǎn)單,而且不需要串口以及相關(guān)驅動(dòng)程序。

4. Logic Analyzer 窗口

在調試的時(shí)候,可以通過(guò)邏輯分析器觀(guān)測至多4個(gè)變量值的變化。執行以下步驟來(lái)使用邏輯分析器。

l 在Cortex-M Target Driver Setup窗口使能Timestamps并選擇合適的Prescaler值。

使用RealView MDK進(jìn)行SW調試和實(shí)時(shí)跟蹤

要想在邏輯分析器的窗口中觀(guān)測到精確的時(shí)間值,必須使能Timestamps。

l 添加準備觀(guān)測的變量到邏輯分析器中

l 在調試過(guò)程中觀(guān)測變量值的變化

使用RealView MDK進(jìn)行SW調試和實(shí)時(shí)跟蹤

5. RTX Kernel Event Viewer 窗口

當運行RTX系統時(shí),RTX Kernel Event Viewer 窗口中顯示了任務(wù)的切換過(guò)程,任務(wù)切換信息通過(guò)專(zhuān)門(mén)的ITM激勵端口31來(lái)傳輸。

執行以下步驟來(lái)使能RTX Kernel Event Viewer。

l 在Cortex-M Target Driver Setup窗口使能ITM 激勵端口31

使用RealView MDK進(jìn)行SW調試和實(shí)時(shí)跟蹤

l 選擇Trace Enable,設置正確的Core Clock。

使用RealView MDK進(jìn)行SW調試和實(shí)時(shí)跟蹤

l 核查T(mén)imestamps為enabled.

使用RealView MDK進(jìn)行SW調試和實(shí)時(shí)跟蹤

l 在目標調試過(guò)程中打開(kāi)RTX Kernel窗口

選擇Peripherals -> RTX Kernel

使用RealView MDK進(jìn)行SW調試和實(shí)時(shí)跟蹤

l 在RTX內核窗口選擇Event Viewer標簽

使用RealView MDK進(jìn)行SW調試和實(shí)時(shí)跟蹤

在窗口中更新了每個(gè)任務(wù)轉換過(guò)程。選擇in或者out按鈕放大或縮小窗口。點(diǎn)擊all按鈕可以顯示所有事件記錄。



評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>