0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學(xué)習在線(xiàn)課程
  • 觀(guān)看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區
會(huì )員中心
創(chuàng )作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內不再提示

一個(gè)超級實(shí)用的單片機調試組件

硬件攻城獅 ? 來(lái)源:CSDN-booksyhay ? 作者:CSDN-booksyhay ? 2023-04-10 11:15 ? 次閱讀

DWT跟蹤組件

跟蹤組件:數據觀(guān)察點(diǎn)與跟蹤(DWT)

e44dfcc0-d6a9-11ed-bfe3-dac502259ad0.png

DWT 中有剩余的計數器,它們典型地用于程序代碼的“性能速寫(xiě)”(profiling)。通過(guò)編程它們,就可以讓它們在計數器溢出時(shí)發(fā)出事件(以跟蹤數據包的形式)。

最典型地,就是使用 CYCCNT寄存器來(lái)測量執行某個(gè)任務(wù)所花的周期數,這也可以用作時(shí)間基準相關(guān)的目的(操作系統中統計 CPU使用率可以用到它)。

Cortex-M中的DWT

在Cortex-M里面有一個(gè)外設叫DWT(Data Watchpoint and Trace),是用于系統調試及跟蹤。

e474b0c2-d6a9-11ed-bfe3-dac502259ad0.png

它有一個(gè)32位的寄存器叫CYCCNT,它是一個(gè)向上的計數器,記錄的是內核時(shí)鐘運行的個(gè)數,內核時(shí)鐘跳動(dòng)一次,該計數器就加1,精度非常高,如果內核時(shí)鐘是72M,那精度就是1/72M = 14ns,而程序的運行時(shí)間都是微秒級別的,所以14ns的精度是遠遠夠的。

最長(cháng)能記錄的時(shí)間為:59.65s。計算方法為2的32次方/72000000。

當CYCCNT溢出之后,會(huì )清0重新開(kāi)始向上計數。

使用方法

要實(shí)現延時(shí)的功能,總共涉及到三個(gè)寄存器:DEMCR 、DWT_CTRL、DWT_CYCCNT,分別用于開(kāi)啟DWT功能、開(kāi)啟CYCCNT及獲得系統時(shí)鐘計數值。

DEMCR

想要使能DWT外設,需要由另外的內核調試寄存器DEMCR的位24控制,寫(xiě)1使能(劃重點(diǎn)啦,要考試?。。?。DEMCR的地址是0xE000 EDFC

e4aff45c-d6a9-11ed-bfe3-dac502259ad0.pnge4e8afe0-d6a9-11ed-bfe3-dac502259ad0.png

關(guān)于DWT_CYCCNT

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

e51fd826-d6a9-11ed-bfe3-dac502259ad0.png

關(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控制寄存器的第一位,寫(xiě)1使能,則啟用CYCCNT計數器,否則CYCCNT計數器將不會(huì )工作。

【https://developer.arm.com/documentation/ddi0337/e/system-debug/dwt/summary-and-description-of-the-dwt-registers?lang=en】

e5491c54-d6a9-11ed-bfe3-dac502259ad0.png

綜上所述

想要使用DWT的CYCCNT步驟:

先使能DWT外設,這個(gè)由另外內核調試寄存器DEMCR的位24控制,寫(xiě)1使能

使能CYCCNT寄存器之前,先清0。

使能CYCCNT寄存器,這個(gè)由DWT的CYCCNTENA 控制,也就是DWT控制寄存器的位0控制,寫(xiě)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<

審核編輯:湯梓紅
聲明:本文內容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權轉載。文章觀(guān)點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習之用,如有內容侵權或者其他違規問(wèn)題,請聯(lián)系本站處理。 舉報投訴
  • 單片機
    +關(guān)注

    關(guān)注

    6008

    文章

    44105

    瀏覽量

    623591
  • 計數器
    +關(guān)注

    關(guān)注

    32

    文章

    2211

    瀏覽量

    93444
  • 調試
    +關(guān)注

    關(guān)注

    7

    文章

    530

    瀏覽量

    33661
  • DWT
    DWT
    +關(guān)注

    關(guān)注

    0

    文章

    20

    瀏覽量

    11017
  • Cortex-M
    +關(guān)注

    關(guān)注

    2

    文章

    224

    瀏覽量

    29601

原文標題:一個(gè)超級實(shí)用的單片機調試組件!

文章出處:【微信號:mcu168,微信公眾號:硬件攻城獅】歡迎添加關(guān)注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    單片機原理及應用: 單片機應用系統設計仿真調試#單片機

    單片機調試
    學(xué)習硬聲知識
    發(fā)布于 :2022年11月09日 00:48:48

    單片機原理及應用: 系統調試#單片機

    單片機調試單片機原理
    學(xué)習硬聲知識
    發(fā)布于 :2022年11月09日 10:42:25

    單片機超級精華包

    單片機超級精華包,下載地址:http://kuai.xunlei.com/d/LACRVHRBJKAX
    發(fā)表于 11-05 23:38

    單片機超級有用工具

    單片機超級有用工具
    發(fā)表于 06-09 14:57

    單片機的程序調試比較辛苦

    現在外行人對這單片機類(lèi)的相關(guān)知識都不怎么了解,因為這個(gè)的確是難度系數太高了。當然大家只要知道怎么運用就好了。我學(xué)習51單片機段時(shí)間了。前
    發(fā)表于 10-22 15:11

    分享個(gè)51的書(shū),及單片機多功能調試助手,含部分章節代...

    本帖最后由 rejoice818 于 2014-2-25 21:56 編輯 分享個(gè)51的書(shū),及調試利器單片機多功能調試助手,本人感覺(jué)
    發(fā)表于 02-25 21:49

    50個(gè)經(jīng)典51單片機超級仿真(附程序+proteus打開(kāi)仿真),

    50個(gè)經(jīng)典541單片機超級仿真(附程序+proteus打開(kāi)仿真),
    發(fā)表于 07-23 14:26

    單片機初學(xué)者必備-單片機超級精華包下載

    強烈推薦單片機初學(xué)者下載,很有學(xué)習價(jià)值的單片機超級精華包?!井厴I(yè)設計】溫度監控系統的設計.rar 2016-4-22 13:51 上傳 點(diǎn)擊文件名下載附件 207.02 KB, 下載次數: 6
    發(fā)表于 07-19 05:05

    單片機開(kāi)發(fā)工具包和單片機開(kāi)發(fā)源程序下載

    單片機開(kāi)發(fā)調試工具包單片機開(kāi)發(fā)源程序超級精華包其中單片機開(kāi)發(fā)工具包總包括有C51我自己的些作品
    發(fā)表于 07-19 02:39

    調試個(gè)ATMEGA88單片機項目

    AVR單片機ATMEGA88利用定時(shí)器2異步時(shí)鐘模式進(jìn)行休眠定時(shí)喚醒時(shí),定時(shí)器不工作的問(wèn)題總結今天調試個(gè)ATMEGA88單片機項目,碰到
    發(fā)表于 11-23 06:51

    Win7超級終端查看單片機printf輸出的方法

    問(wèn)題描述:編寫(xiě)單片機C程序時(shí),經(jīng)常會(huì )用到printf輸出信息進(jìn)行查看,如何查看printf輸出?問(wèn)題解決:(1)編寫(xiě)單片機C程序ucos是個(gè)實(shí)時(shí)多任務(wù)操作系統,以上是
    發(fā)表于 01-12 07:03

    超級單片機軟件工具

    超級單片機軟件工具 軟件工具
    發(fā)表于 11-01 17:16 ?179次下載

    單片機開(kāi)發(fā)調試應注意的問(wèn)題

    單片機開(kāi)發(fā)調試應注意的問(wèn)題 1、使用總線(xiàn)不外引的單片機 ·是最正統的單片機使用模式 ·符合小型、簡(jiǎn)單、可靠、廉價(jià)的單片機設計初衷
    發(fā)表于 03-26 12:30 ?1683次閱讀

    單片機調試過(guò)程中的調試組件導致的問(wèn)題

    單片機調試過(guò)程中,經(jīng)常會(huì )遇到類(lèi)似第3只眼的問(wèn)題。何謂第3只眼呢?
    的頭像 發(fā)表于 12-30 17:12 ?7167次閱讀
    <b class='flag-5'>單片機</b><b class='flag-5'>調試</b>過(guò)程中的<b class='flag-5'>調試</b><b class='flag-5'>組件</b>導致的問(wèn)題

    一個(gè)超級實(shí)用的單片機調試組件!

    DWT 中有剩余的計數器,它們典型地用于程序代碼的“性能速寫(xiě)”(profiling)。通過(guò)編程它們,就可以讓它們在計數器溢出時(shí)發(fā)出事件(以跟蹤數據包的形式)。
    發(fā)表于 05-23 10:01 ?255次閱讀
     一個(gè)<b class='flag-5'>超級</b>實(shí)用的<b class='flag-5'>單片機</b><b class='flag-5'>調試</b><b class='flag-5'>組件</b>!
    亚洲欧美日韩精品久久_久久精品AⅤ无码中文_日本中文字幕有码在线播放_亚洲视频高清不卡在线观看