chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

3天內(nèi)不再提示

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

硬件攻城獅 ? 來源:CSDN-booksyhay ? 作者:CSDN-booksyhay ? 2023-04-10 11:15 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

DWT跟蹤組件

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

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

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

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

Cortex-M中的DWT

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

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

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

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

當(dāng)CYCCNT溢出之后,會(huì)清0重新開始向上計(jì)數(shù)。

使用方法

要實(shí)現(xiàn)延時(shí)的功能,總共涉及到三個(gè)寄存器:DEMCR 、DWT_CTRL、DWT_CYCCNT,分別用于開啟DWT功能、開啟CYCCNT及獲得系統(tǒng)時(shí)鐘計(jì)數(shù)值。

DEMCR

想要使能DWT外設(shè),需要由另外的內(nèi)核調(diào)試寄存器DEMCR的位24控制,寫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手冊(cè)中可以看到其基地址是0xE000 1004,復(fù)位默認(rèn)值是0,而且它的類型是可讀可寫的,我們往0xE000 1004這個(gè)地址寫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控制寄存器的第一位,寫1使能,則啟用CYCCNT計(jì)數(shù)器,否則CYCCNT計(jì)數(shù)器將不會(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外設(shè),這個(gè)由另外內(nèi)核調(diào)試寄存器DEMCR的位24控制,寫1使能

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

使能CYCCNT寄存器,這個(gè)由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<

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

    關(guān)注

    6067

    文章

    44992

    瀏覽量

    650599
  • 計(jì)數(shù)器
    +關(guān)注

    關(guān)注

    32

    文章

    2291

    瀏覽量

    96425
  • 調(diào)試
    +關(guān)注

    關(guān)注

    7

    文章

    612

    瀏覽量

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

    關(guān)注

    0

    文章

    20

    瀏覽量

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

    關(guān)注

    2

    文章

    231

    瀏覽量

    30390

原文標(biāo)題:一個(gè)超級(jí)實(shí)用的單片機(jī)調(diào)試組件!

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

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    單片機(jī)串口模塊調(diào)試方法

    筆者在調(diào)試某Cortex-M3內(nèi)核單片機(jī)時(shí)遇到個(gè)問題,此單片機(jī)不具備在線仿真功能,因此調(diào)試代碼
    發(fā)表于 07-28 15:48 ?1935次閱讀
    <b class='flag-5'>單片機(jī)</b>串口模塊<b class='flag-5'>調(diào)試</b>方法

    單片機(jī)的在線調(diào)試方法

    本文主要講述的是單片機(jī)的在線調(diào)試方法。
    發(fā)表于 04-22 16:43 ?34次下載

    ARM單片機(jī)開發(fā)調(diào)試方法

    ARM單片機(jī)開發(fā)調(diào)試方法
    發(fā)表于 07-25 13:21 ?36次下載

    超級(jí)單片機(jī)軟件工具

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

    單片機(jī)開發(fā)調(diào)試應(yīng)注意的問題

    單片機(jī)開發(fā)調(diào)試應(yīng)注意的問題 1、使用總線不外引的單片機(jī) ·是最正統(tǒng)的單片機(jī)使用模式 ·符合小型、簡(jiǎn)單、可靠、廉價(jià)的單片機(jī)設(shè)計(jì)初衷
    發(fā)表于 03-26 12:30 ?1803次閱讀

    單片機(jī)多功能調(diào)試助手

    單片機(jī)多功能調(diào)試助手。
    發(fā)表于 01-12 16:52 ?7次下載

    單片機(jī)多功能調(diào)試助手

    單片機(jī)多功能調(diào)試助手 串口、USB等調(diào)試用。
    發(fā)表于 03-11 10:34 ?8次下載

    單片機(jī)個(gè)項(xiàng)目的開發(fā)和設(shè)計(jì)及調(diào)試等資料說明

    本文檔的主要內(nèi)容詳細(xì)介紹的是單片機(jī)個(gè)項(xiàng)目的開發(fā)和設(shè)計(jì)及調(diào)試等資料說明。仿照書中實(shí)例按步驟完成以下項(xiàng)目的開發(fā)、硬件軟件的設(shè)計(jì)和調(diào)試
    發(fā)表于 05-30 08:00 ?0次下載
    <b class='flag-5'>單片機(jī)</b>的<b class='flag-5'>一</b><b class='flag-5'>個(gè)</b>項(xiàng)目的開發(fā)和設(shè)計(jì)及<b class='flag-5'>調(diào)試</b>等資料說明

    單片機(jī)系統(tǒng)硬件的靜態(tài)調(diào)試和動(dòng)態(tài)調(diào)試綜述

    單片機(jī)系統(tǒng)硬件的靜態(tài)調(diào)試和動(dòng)態(tài)調(diào)試綜述
    發(fā)表于 07-18 10:59 ?2次下載

    個(gè)超級(jí)實(shí)用的單片機(jī)調(diào)試組件!

    DWT 中有剩余的計(jì)數(shù)器,它們典型地用于程序代碼的“性能速寫”(profiling)。通過編程它們,就可以讓它們?cè)谟?jì)數(shù)器溢出時(shí)發(fā)出事件(以跟蹤數(shù)據(jù)包的形式)。
    發(fā)表于 05-23 10:01 ?564次閱讀
     <b class='flag-5'>一</b><b class='flag-5'>個(gè)</b><b class='flag-5'>超級(jí)</b>實(shí)用的<b class='flag-5'>單片機(jī)</b><b class='flag-5'>調(diào)試</b><b class='flag-5'>組件</b>!

    單片機(jī)開發(fā)調(diào)試工具有哪些?

    單片機(jī)調(diào)試個(gè)有條不紊的過程,用于查找和減少單片機(jī)程序中的錯(cuò)誤數(shù)量,使其按預(yù)期工作。有時(shí)候,單片機(jī)
    的頭像 發(fā)表于 07-07 12:29 ?2010次閱讀

    單片機(jī)調(diào)試時(shí)的那些技術(shù)

    單片機(jī)調(diào)試時(shí)的那些技術(shù)
    的頭像 發(fā)表于 10-18 17:56 ?1182次閱讀
    <b class='flag-5'>單片機(jī)</b><b class='flag-5'>調(diào)試</b>時(shí)的那些技術(shù)

    應(yīng)用單片機(jī)開發(fā)的ST LINK調(diào)試器設(shè)計(jì)制作

    調(diào)試ST單片機(jī)的過程中,ST-LINK是個(gè)很好使用的調(diào)試工具。今天,我們就根據(jù)網(wǎng)絡(luò)上的設(shè)計(jì)方案進(jìn)行簡(jiǎn)化,設(shè)計(jì)制作
    發(fā)表于 03-06 10:26 ?1842次閱讀
    應(yīng)用<b class='flag-5'>單片機(jī)</b>開發(fā)的ST LINK<b class='flag-5'>調(diào)試</b>器設(shè)計(jì)制作

    單片機(jī)基本io功能調(diào)試過程

    單片機(jī)基本IO功能的調(diào)試過程涉及多個(gè)步驟,旨在確保IO口能夠正確地執(zhí)行輸入和輸出操作。以下是個(gè)調(diào)試過程,涵蓋了從準(zhǔn)備階段到實(shí)際測(cè)試的關(guān)鍵步
    的頭像 發(fā)表于 09-14 14:38 ?1487次閱讀

    單片機(jī)Debug工具性能對(duì)比 單片機(jī)調(diào)試常用命令

    單片機(jī)(Microcontroller Unit, MCU)調(diào)試是嵌入式開發(fā)中的個(gè)重要環(huán)節(jié),它幫助開發(fā)者發(fā)現(xiàn)和修復(fù)代碼中的錯(cuò)誤,優(yōu)化程序性能。不同的
    的頭像 發(fā)表于 12-19 09:56 ?1424次閱讀