DWT跟蹤組件
跟蹤組件:數(shù)據(jù)觀察點(diǎn)與跟蹤(DWT)

DWT 中有剩余的計數(shù)器,它們典型地用于程序代碼的“性能速寫”(profiling)。通過編程它們,就可以讓它們在計數(shù)器溢出時發(fā)出事件(以跟蹤數(shù)據(jù)包的形式)。
最典型地,就是使用 CYCCNT寄存器來測量執(zhí)行某個任務(wù)所花的周期數(shù),這也可以用作時間基準(zhǔn)相關(guān)的目的(操作系統(tǒng)中統(tǒng)計 CPU使用率可以用到它)。
Cortex-M中的DWT
在Cortex-M里面有一個外設(shè)叫DWT(Data Watchpoint and Trace),是用于系統(tǒng)調(diào)試及跟蹤。

它有一個32位的寄存器叫CYCCNT,它是一個向上的計數(shù)器,記錄的是內(nèi)核時鐘運(yùn)行的個數(shù),內(nèi)核時鐘跳動一次,該計數(shù)器就加1,精度非常高,如果內(nèi)核時鐘是72M,那精度就是1/72M = 14ns,而程序的運(yùn)行時間都是微秒級別的,所以14ns的精度是遠(yuǎn)遠(yuǎn)夠的。
最長能記錄的時間為:59.65s。計算方法為2的32次方/72000000。
當(dāng)CYCCNT溢出之后,會清0重新開始向上計數(shù)。
使用方法
要實(shí)現(xiàn)延時的功能,總共涉及到三個寄存器:DEMCR 、DWT_CTRL、DWT_CYCCNT,分別用于開啟DWT功能、開啟CYCCNT及獲得系統(tǒng)時鐘計數(shù)值。
DEMCR
想要使能DWT外設(shè),需要由另外的內(nèi)核調(diào)試寄存器DEMCR的位24控制,寫1使能(劃重點(diǎn)啦,要考試?。。?。DEMCR的地址是0xE000 EDFC


關(guān)于DWT_CYCCNT
使能DWT_CYCCNT寄存器之前,先清0。讓我們看看DWT_CYCCNT的基地址,從ARM-Cortex-M手冊中可以看到其基地址是0xE000 1004,復(fù)位默認(rèn)值是0,而且它的類型是可讀可寫的,我們往0xE000 1004這個地址寫0就將DWT_CYCCNT清0了。

關(guān)于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計數(shù)器,否則CYCCNT計數(shù)器將不會工作。
【https://developer.arm.com/documentation/ddi0337/e/system-debug/dwt/summary-and-description-of-the-dwt-registers?lang=en】

綜上所述
想要使用DWT的CYCCNT步驟:
先使能DWT外設(shè),這個由另外內(nèi)核調(diào)試寄存器DEMCR的位24控制,寫1使能
使能CYCCNT寄存器之前,先清0。
使能CYCCNT寄存器,這個由DWT的CYCCNTENA 控制,也就是DWT控制寄存器的位0控制,寫1使能
寄存器定義:
//0xE000EDFCDEMCRRWDebugExceptionandMonitorControlRegister. //使能DWT模塊的功能位 #defineDEMCR(*(unsignedint*)0xE000EDFC) #defineTRCENA(0x01<24)?//?DEMCR的DWT使能位?? ?? //0xE0001000?DWT_CTRL?RW?The?Debug?Watchpoint?and?Trace?(DWT)?unit?? //使能CYCCNT計數(shù)器開始計數(shù) #define?DWT_CTRL????????(?*(unsigned?int?*)0xE0001000?)?? #define?CYCCNTENA???????(?0x01?<0?)?//?DWT的SYCCNT使能位 ? //0xE0001004?DWT_CYCCNT?RW?Cycle?Count?register,??? //CYCCNT計數(shù)器的內(nèi)部值(32位無符號) #define?DWT_CYCCNT??????(?*(unsigned?int?*)0xE0001004)?//顯示或設(shè)置處理器的周期計數(shù)值??
用法示例:
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<24)
?
#define??DWT_CR_CYCCNTENA????????????????(1?<?0)
?
/*?初始化時間戳?*/
?
void?CPU_TS_TmrInit(void)
?
{
?
????????/*?使能DWT外設(shè)?*/
????????DEM_CR?|=?(uint32_t)DEM_CR_TRCENA;???????????????
?
????????/*?DWT?CYCCNT寄存器計數(shù)清0?*/
????????DWT_CYCCNT?=?(uint32_t)0u;
???????
?
????????/*?使能Cortex-M3?DWT?CYCCNT寄存器?*/
????????DWT_CR?|=?(uint32_t)DWT_CR_CYCCNTENA;
?
}
?
uint32_t?OS_TS_GET(void)
{???????
?
????????return?((uint32_t)DWT_CYCCNT);
?
}
-
單片機(jī)
+關(guān)注
關(guān)注
6076文章
45492瀏覽量
670137 -
計數(shù)器
+關(guān)注
關(guān)注
32文章
2315瀏覽量
98164 -
調(diào)試
+關(guān)注
關(guān)注
7文章
646瀏覽量
35635 -
DWT
+關(guān)注
關(guān)注
0文章
20瀏覽量
11583 -
Cortex-M
+關(guān)注
關(guān)注
2文章
234瀏覽量
31088
原文標(biāo)題:一個超級實(shí)用的單片機(jī)調(diào)試組件!
文章出處:【微信號:mcu168,微信公眾號:硬件攻城獅】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
單片機(jī)串口模塊調(diào)試方法
了解單片機(jī)及單片機(jī)的控制原理和DX516的用法,控制一個LE
單片機(jī)開發(fā)調(diào)試應(yīng)注意的問題
單片機(jī)的一個項(xiàng)目的開發(fā)和設(shè)計及調(diào)試等資料說明
單片機(jī)系統(tǒng)硬件的靜態(tài)調(diào)試和動態(tài)調(diào)試綜述
一個超級實(shí)用的單片機(jī)調(diào)試組件!
單片機(jī)開發(fā)調(diào)試工具有哪些?
應(yīng)用單片機(jī)開發(fā)的ST LINK調(diào)試器設(shè)計制作
一個超級實(shí)用的單片機(jī)調(diào)試組件
評論