哈哈哈哈哈操欧洲电影,久草网在线,亚洲久久熟女熟妇视频,麻豆精品色,久久福利在线视频,日韩中文字幕的,淫乱毛视频一区,亚洲成人一二三,中文人妻日韩精品电影

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

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

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

一個超級實用的單片機調(diào)試組件

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

掃碼添加小助手

加入工程師交流群

DWT跟蹤組件

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

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

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

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

Cortex-M中的DWT

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

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

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

最長能記錄的時間為:59.65s。計算方法為2的32次方/72000000。

當CYCCNT溢出之后,會清0重新開始向上計數(shù)。

使用方法

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

DEMCR

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

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

關于DWT_CYCCNT

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

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

關于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】

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

綜上所述

想要使用DWT的CYCCNT步驟:

先使能DWT外設,這個由另外內(nèi)核調(diào)試寄存器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<

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

    關注

    6078

    文章

    45576

    瀏覽量

    673504
  • 計數(shù)器
    +關注

    關注

    32

    文章

    2321

    瀏覽量

    98540
  • 調(diào)試
    +關注

    關注

    7

    文章

    653

    瀏覽量

    35874
  • DWT
    DWT
    +關注

    關注

    0

    文章

    20

    瀏覽量

    11603
  • Cortex-M
    +關注

    關注

    2

    文章

    234

    瀏覽量

    31190

原文標題:一個超級實用的單片機調(diào)試組件!

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

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

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

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

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

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

    了解單片機單片機的控制原理和DX516的用法,控制LE

    本章學習內(nèi)容:單片機基本原理,如何使用DX516仿真器,如何編程點亮和滅掉LED燈,如何進入KEILC51uV調(diào)試環(huán)境,如何使用單步,斷點,全速,停止的
    發(fā)表于 09-09 17:22 ?42次下載

    超級單片機軟件工具

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

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

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

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

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

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

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

    單片機項目的開發(fā)和設計及調(diào)試等資料說明

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

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

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

    超級實用的單片機調(diào)試組件!

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

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

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

    單片機調(diào)試時的那些技術

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

    應用單片機開發(fā)的ST LINK調(diào)試器設計制作

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

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

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

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

    單片機(Microcontroller Unit, MCU)調(diào)試是嵌入式開發(fā)中的重要環(huán)節(jié),它幫助開發(fā)者發(fā)現(xiàn)和修復代碼中的錯誤,優(yōu)化程序性能。不同的
    的頭像 發(fā)表于 12-19 09:56 ?2630次閱讀
    克什克腾旗| 万载县| 沙田区| 海兴县| 衡水市| 顺平县| 甘谷县| 百色市| 泰宁县| 曲沃县| 福泉市| 濮阳县| 大同市| 稻城县| 嵊州市| 凤城市| 金川县| 惠安县| 葵青区| 辰溪县| 平泉县| 年辖:市辖区| 怀来县| 广元市| 同江市| 都江堰市| 老河口市| 洪泽县| 剑河县| 阿拉善左旗| 浮山县| 高要市| 格尔木市| 松溪县| 年辖:市辖区| 桐柏县| 会宁县| 塔河县| 崇阳县| 铜川市| 额尔古纳市|