DWT跟蹤組件
跟蹤組件:數據觀察點與跟蹤(DWT)
DWT 中有剩余的計數器,它們典型地用于程序代碼的“性能速寫”(profiling)。通過編程它們,就可以讓它們在計數器溢出時發出事件(以跟蹤數據包的形式)。
最典型地,就是使用 CYCCNT寄存器來測量執行某個任務所花的周期數,這也可以用作時間基準相關的目的(操作系統中統計 CPU使用率可以用到它)。
Cortex-M中的DWT
在Cortex-M里面有一個外設叫DWT(Data Watchpoint and Trace),是用于系統調試及跟蹤。
它有一個32位的寄存器叫CYCCNT,它是一個向上的計數器,記錄的是內核時鐘運行的個數,內核時鐘跳動一次,該計數器就加1,精度非常高,如果內核時鐘是72M,那精度就是1/72M = 14ns,而程序的運行時間都是微秒級別的,所以14ns的精度是遠遠夠的。
最長能記錄的時間為:59.65s。計算方法為2的32次方/72000000。
當CYCCNT溢出之后,會清0重新開始向上計數。
使用方法
要實現延時的功能,總共涉及到三個寄存器:DEMCR 、DWT_CTRL、DWT_CYCCNT,分別用于開啟DWT功能、開啟CYCCNT及獲得系統時鐘計數值。
DEMCR
想要使能DWT外設,需要由另外的內核調試寄存器DEMCR的位24控制,寫1使能(劃重點啦,要考試?。。?。DEMCR的地址是0xE000 EDFC
關于DWT_CYCCNT
使能DWT_CYCCNT寄存器之前,先清0。讓我們看看DWT_CYCCNT的基地址,從ARM-Cortex-M手冊中可以看到其基地址是0xE000 1004,復位默認值是0,而且它的類型是可讀可寫的,我們往0xE000 1004這個地址寫0就將DWT_CYCCNT清0了。
關于CYCCNTENA
CYCCNTENA Enable the CYCCNT counter. If not enabled, the counter does not count and no event is generated for PS sampling or CYCCNTENA. In normal use, the debugger must initialize the CYCCNT counter to 0.
它是DWT控制寄存器的第一位,寫1使能,則啟用CYCCNT計數器,否則CYCCNT計數器將不會工作。
【https://developer.arm.com/documentation/ddi0337/e/system-debug/dwt/summary-and-description-of-the-dwt-registers?lang=en】
綜上所述
想要使用DWT的CYCCNT步驟:
先使能DWT外設,這個由另外內核調試寄存器DEMCR的位24控制,寫1使能
使能CYCCNT寄存器之前,先清0。
使能CYCCNT寄存器,這個由DWT的CYCCNTENA 控制,也就是DWT控制寄存器的位0控制,寫1使能
寄存器定義:
//0xE000EDFCDEMCRRWDebugExceptionandMonitorControlRegister. //使能DWT模塊的功能位 #defineDEMCR(*(unsignedint*)0xE000EDFC) #defineTRCENA(0x01<
用法示例:
vvolatileunsignedint*DWT_CYCCNT; volatileunsignedint*DWT_CONTROL; volatileunsignedint*SCB_DEMCR; voidreset_timer(){ DWT_CYCCNT=(int*)0xE0001004;//addressoftheregister DWT_CONTROL=(int*)0xE0001000;//addressoftheregister SCB_DEMCR=(int*)0xE000EDFC;//addressoftheregister *SCB_DEMCR=*SCB_DEMCR|0x01000000; *DWT_CYCCNT=0;//resetthecounter *DWT_CONTROL=0; } voidstart_timer(){ *DWT_CONTROL=*DWT_CONTROL|1;//enablethecounter } voidstop_timer(){ *DWT_CONTROL=*DWT_CONTROL|0;//disablethecounter } unsignedintgetCycles(){ return*DWT_CYCCNT; } main(){ .... reset_timer();//resettimer start_timer();//starttimer //Codetoprofile ... myFunction(); ... stop_timer();//stoptimer numCycles=getCycles();//readnumberofcycles ... }
示例2:
#definestart_timer()*((volatileuint32_t*)0xE0001000)=0x40000001//EnableCYCCNTregister #definestop_timer()*((volatileuint32_t*)0xE0001000)=0x40000000//DisableCYCCNTregister #defineget_timer()*((volatileuint32_t*)0xE0001004)//GetvaluefromCYCCNTregister /*********** *Howtouse: *uint32_tit1,it2;//startandstopflag start_timer();//startthetimer. it1=get_timer();//storecurrentcycle-countinalocal //dosomething it2=get_timer()-it1;//Derivethecycle-countdifference stop_timer();//Iftimerisnotneededanymore,stop print_int(it2);//Displaythedifference ****/
示例3:
#defineDWT_CR*(uint32_t*)0xE0001000 #defineDWT_CYCCNT*(uint32_t*)0xE0001004 #defineDEM_CR*(uint32_t*)0xE000EDFC #defineDEM_CR_TRCENA(1<
審核編輯:彭靜
-
寄存器
+關注
關注
31文章
5397瀏覽量
122682 -
計數器
+關注
關注
32文章
2282瀏覽量
95801 -
DWT
+關注
關注
0文章
20瀏覽量
11256
原文標題:分享一個超實用的單片機調試技巧!DWT組件
文章出處:【微信號:mcu168,微信公眾號:硬件攻城獅】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
詳解DWT跟蹤組件的單片機調試技巧
ComponentCodelab——Tablist的使用方法
DWT的相關資料下載
AT32使用內核DWT寄存器設定延時時間
如何使用高級配置和電源接口(ACPI)支持CoreSight跟蹤組件
電力電纜局部放電測量DWT技術

示波器的使用方法(三):示波器的使用方法詳解
羅森伯格HFM電纜組件的使用方法
STM32“隱藏的定時器”-DWT

射頻電纜組件的使用方法和注意事項
揭秘單片機調試利器值之DWT跟蹤組件

太陽能組件檢測設備的使用方法簡單嗎?
LangChain框架關鍵組件的使用方法

評論