<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > 使用RealView MDK進行SW調(diào)試和實時跟蹤

          使用RealView MDK進行SW調(diào)試和實時跟蹤

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

          一、目標(biāo)調(diào)試階段的配置

          1. 調(diào)試器的選擇

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

          使用RealView MDK進行SW調(diào)試和實時跟蹤

          2. 調(diào)試目標(biāo)初始化文件

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

          使用RealView MDK進行SW調(diào)試和實時跟蹤

          3. Cortex-M 目標(biāo)設(shè)備調(diào)試驅(qū)動配置

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

          使用RealView MDK進行SW調(diào)試和實時跟蹤

          4. Trace功能的配置

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

          使用RealView MDK進行SW調(diào)試和實時跟蹤

          二、

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

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

          使用RealView MDK進行SW調(diào)試和實時跟蹤

          2. 窗口

          調(diào)試時選擇Peripherals – Trace。

          使用RealView MDK進行SW調(diào)試和實時跟蹤

          1) Trace Records窗口

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

          使用RealView MDK進行SW調(diào)試和實時跟蹤

          2) Exception Trace 窗口

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

          使用RealView MDK進行SW調(diào)試和實時跟蹤

          3) Event Counters窗口

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

          使用RealView MDK進行SW調(diào)試和實時跟蹤

          3. ITM Viewer窗口

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

          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函數(shù),它向ITM的激勵端口0寄存器寫數(shù)據(jù)。如果有了fputc函數(shù),則可以用printf函數(shù)做為調(diào)試輸出。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函數(shù)來顯示調(diào)試跟蹤信息。

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

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

          使用RealView MDK進行SW調(diào)試和實時跟蹤

          l 在目標(biāo)調(diào)試期,打開ITM Viewer窗口

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

          使用RealView MDK進行SW調(diào)試和實時跟蹤

          完成這些步驟以后,可以在目標(biāo)調(diào)試期通過ITM Viewer窗口查看到調(diào)試跟蹤信息,例如顯示AD轉(zhuǎn)換的結(jié)果。

          使用RealView MDK進行SW調(diào)試和實時跟蹤

          ITM Viewer的功能類似串口打印調(diào)試信息,使用ITM更簡單,而且不需要串口以及相關(guān)驅(qū)動程序。

          4. Logic Analyzer 窗口

          在調(diào)試的時候,可以通過邏輯分析器觀測至多4個變量值的變化。執(zhí)行以下步驟來使用邏輯分析器。

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

          使用RealView MDK進行SW調(diào)試和實時跟蹤

          要想在邏輯分析器的窗口中觀測到精確的時間值,必須使能Timestamps。

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

          l 在調(diào)試過程中觀測變量值的變化

          使用RealView MDK進行SW調(diào)試和實時跟蹤

          5. RTX Kernel Event Viewer 窗口

          當(dāng)運行RTX系統(tǒng)時,RTX Kernel Event Viewer 窗口中顯示了任務(wù)的切換過程,任務(wù)切換信息通過專門的ITM激勵端口31來傳輸。

          執(zhí)行以下步驟來使能RTX Kernel Event Viewer。

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

          使用RealView MDK進行SW調(diào)試和實時跟蹤

          l 選擇Trace Enable,設(shè)置正確的Core Clock。

          使用RealView MDK進行SW調(diào)試和實時跟蹤

          l 核查Timestamps為enabled.

          使用RealView MDK進行SW調(diào)試和實時跟蹤

          l 在目標(biāo)調(diào)試過程中打開RTX Kernel窗口

          選擇Peripherals -> RTX Kernel

          使用RealView MDK進行SW調(diào)試和實時跟蹤

          l 在RTX內(nèi)核窗口選擇Event Viewer標(biāo)簽

          使用RealView MDK進行SW調(diào)試和實時跟蹤

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



          評論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();