在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

3天內不再提示

DWT跟蹤組件調試

科技綠洲 ? 來源:一起學嵌入式 ? 作者:一起學嵌入式 ? 2023-06-22 14:24 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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步驟:

  1. 先使能DWT外設,這個由另外內核調試寄存器 DEMCR 的位24控制,寫1使能
  2. 使能CYCCNT寄存器之前,先清 0。
  3. 使能CYCCNT寄存器,這個由DWT的CYCCNTENA 控制,也就是DWT控制寄存器的位0控制,寫1使能

寄存器定義:

//0xE000EDFC DEMCR RW Debug Exception and Monitor Control Register.  
//使能DWT模塊的功能位
#define DEMCR           ( *(unsigned int *)0xE000EDFC )  
#define TRCENA          ( 0x01 < < 24) // DEMCR的DWT使能位  
  
//0xE0001000 DWT_CTRL RW The Debug Watchpoint and Trace (DWT) unit  
//使能CYCCNT計數器開始計數
#define DWT_CTRL        ( *(unsigned int *)0xE0001000 )  
#define CYCCNTENA       ( 0x01 < < 0 ) // DWT的SYCCNT使能位
 
//0xE0001004 DWT_CYCCNT RW Cycle Count register,   
//CYCCNT計數器的內部值(32位無符號)
#define DWT_CYCCNT      ( *(unsigned int *)0xE0001004) //顯示或設置處理器的周期計數值

用法示例:

vvolatile unsigned int *DWT_CYCCNT  ;
volatile unsigned int *DWT_CONTROL ;
volatile unsigned int *SCB_DEMCR   ;
 
void reset_timer(){
    DWT_CYCCNT   = (int *)0xE0001004; //address of the register
    DWT_CONTROL  = (int *)0xE0001000; //address of the register
    SCB_DEMCR    = (int *)0xE000EDFC; //address of the register
    *SCB_DEMCR   = *SCB_DEMCR | 0x01000000;
    *DWT_CYCCNT  = 0; // reset the counter
    *DWT_CONTROL = 0; 
}
 
void start_timer(){
    *DWT_CONTROL = *DWT_CONTROL | 1 ; // enable the counter
}
 
void stop_timer(){
    *DWT_CONTROL = *DWT_CONTROL | 0 ; // disable the counter    
}
 
unsigned int getCycles(){
    return *DWT_CYCCNT;
}
 
main(){
    ....
    reset_timer(); //reset timer
    start_timer(); //start timer
    //Code to profile
    ...
    myFunction();
    ...
    stop_timer(); //stop timer
    numCycles = getCycles(); //read number of cycles 
    ...
}

示例2:

#define start_timer()    *((volatile uint32_t*)0xE0001000) = 0x40000001  // Enable CYCCNT register
#define stop_timer()   *((volatile uint32_t*)0xE0001000) = 0x40000000  // Disable CYCCNT register
#define get_timer()   *((volatile uint32_t*)0xE0001004)               // Get value from CYCCNT register
 
/***********
* How to use:
*       uint32_t it1, it2;      // start and stop flag                                            
        start_timer();          // start the timer.
        it1 = get_timer();      // store current cycle-count in a local
        // do something
        it2 = get_timer() - it1;    // Derive the cycle-count difference
        stop_timer();               // If timer is not needed any more, stop
print_int(it2);                 // Display the difference
****/

示例3:

#define  DWT_CR      *(uint32_t *)0xE0001000
 
#define  DWT_CYCCNT  *(uint32_t *)0xE0001004
 
#define  DEM_CR      *(uint32_t *)0xE000EDFC
 
#define  DEM_CR_TRCENA                  (1 < < 24)
 
#define  DWT_CR_CYCCNTENA                (1 < <  0)
 
/* 初始化時間戳 */
 
void CPU_TS_TmrInit(void)
{
        /* 使能DWT外設 */
        DEM_CR |= (uint32_t)DEM_CR_TRCENA;               
 
        /* DWT CYCCNT寄存器計數清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);
}
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 寄存器
    +關注

    關注

    31

    文章

    5429

    瀏覽量

    123839
  • cpu
    cpu
    +關注

    關注

    68

    文章

    11059

    瀏覽量

    216406
  • DWT
    DWT
    +關注

    關注

    0

    文章

    20

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    詳解DWT跟蹤組件的單片機調試技巧

    DWT 中有剩余的計數器,它們典型地用于程序代碼的“性能速寫”(profiling)。通過編程它們,就可以讓它們在計數器溢出時發出事件(以跟蹤數據包的形式)。
    發表于 10-03 06:42 ?798次閱讀

    DWT跟蹤組件使用方法

    DWT 中有剩余的計數器,它們典型地用于程序代碼的“性能速寫”(profiling)。通過編程它們,就可以讓它們在計數器溢出時發出事件(以跟蹤數據包的形式)。
    的頭像 發表于 10-09 10:14 ?2111次閱讀

    一個超級實用的單片機調試組件

    DWT 中有剩余的計數器,它們典型地用于程序代碼的“性能速寫”(profiling)。通過編程它們,就可以讓它們在計數器溢出時發出事件(以跟蹤數據包的形式)。
    的頭像 發表于 04-10 11:15 ?3116次閱讀

    DWT的相關資料下載

    特定應用場景下定時器外設資源是十分稀缺的。在留言區有位大佬提到可以使用DWT,我就研究了一番。02、DWT在Cortex-M里面有一個外設叫DWT(DataWatchpoint andTrace),是用于系統
    發表于 02-07 09:19

    在STM32F10x中支持哪幾種調試接口呢

    中,支持兩種調試接口:1、串行接口;2、JATAG調試接口其調試框圖如下:由以下幾部分組成:SWJ-DP:串行/JTAG調試端口AHP-AP:AHB訪問端口ITM:執行
    發表于 03-02 07:12

    AT32使用內核DWT寄存器設定延時時間

    AT32使用內核DWT寄存器設定延時時間示例目的本示例代碼展示了如何使用 AT32 的內核 DWT 寄存器設定延時時間。與 SysTick 類似,使用 DWT也可以得到基于 Cortex-M 內核
    發表于 07-19 20:18

    如何使用或啟用STM32CubeIDE DWT

    我有一塊 STM32L031K6 Nucleo 板……我想使用 DWT.. 但我變成了這個錯誤:../Core/Src/../Inc/stm32_delay.h:35:30: error: 'DWT
    發表于 01-30 06:38

    如何使用高級配置和電源接口(ACPI)支持CoreSight跟蹤組件

    本規范描述了如何使用高級配置和電源接口(ACPI)支持CoreSight[1]跟蹤組件。該規范基于ACPI _DSD圖形規范[2],該規范提供了對表示作為一組連接設備排列的系統組件的支持
    發表于 08-08 06:16

    使用RealView MDK進行SW調試和實時跟蹤

    使用RealView MDK進行SW調試和實時跟蹤 STM32有兩個調試端口,即JTAG和SW。Keil 的ULINK2 USB
    發表于 08-02 09:27 ?4636次閱讀
    使用RealView MDK進行SW<b class='flag-5'>調試</b>和實時<b class='flag-5'>跟蹤</b>

    關于CoreSight中調試跟蹤的相關內容

    如今眾多Cortex-M處理器能這么方便調試,在于有一項基于Arm Cortex-M處理器設備的CoreSight技術,該技術引入了強大的新調試(Debug)和跟蹤(Trace)功能。 下面就來重點
    的頭像 發表于 11-03 16:10 ?2357次閱讀

    STM32“隱藏的定時器”-DWT

    特定應用場景下定時器外設資源是十分稀缺的。在留言區有位大佬提到可以使用DWT,我就研究了一番。02、DWT在Cortex-M里面有一個外設叫DWT(DataWatchpoint andTrace),是用于系統
    發表于 12-04 14:51 ?1次下載
    STM32“隱藏的定時器”-<b class='flag-5'>DWT</b>

    詳解CoreSight技術中的調試跟蹤功能

    如今眾多Cortex-M處理器能這么方便調試,在于有一項基于Arm Cortex-M處理器設備的CoreSight技術,該技術引入了強大的新調試(Debug)和跟蹤(Trace)功能。
    的頭像 發表于 04-12 20:16 ?5689次閱讀

    一個超級實用的單片機調試組件

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

    RISC-V調試和完善的跟蹤解決方案

    RISC-V調試和完善的跟蹤解決方案ppt分享
    發表于 07-14 17:15 ?2次下載

    揭秘單片機調試利器值之DWT跟蹤組件

    DWT 中有剩余的計數器,它們典型地用于程序代碼的“性能速寫”(profiling)。通過編程它們,就可以讓它們在計數器溢出時發出事件(以跟蹤數據包的形式)。
    發表于 02-28 13:55 ?1295次閱讀
    揭秘單片機<b class='flag-5'>調試</b>利器值之<b class='flag-5'>DWT</b><b class='flag-5'>跟蹤</b><b class='flag-5'>組件</b>
    主站蜘蛛池模板: 欧美高清一区二区三 | 在线亚洲精品 | 男女交性动态免费视频 | 天天干天天操天天透 | 国产高清在线 | 日本一区高清视频 | 午夜剧场操一操 | bl 高h文| 广东毛片| 一区二区中文字幕亚洲精品 | 四虎国产成人亚洲精品 | 久久久精品2021免费观看 | www.五月婷婷.com | 女攻各种play男受h | 色吧视频 | 日韩成a人片在线观看日本 日韩成人黄色 | 天天操天天干天天摸 | 狠狠狠| 看大片全色黄大色黄 | 91男人| 欧美一级特黄乱妇高清视频 | 啪啪小视频网站 | 手机看高清特黄a大片 | 91美女在线播放 | 黄色片xxxx | 夜夜操夜夜骑 | 男人操女人视频免费 | 久久精品五月天 | 午夜 福利 视频 | 国产三级精品视频 | 丁香婷婷激情综合 | 女人张开腿等男人桶免费视频 | 亚洲国产精品国产自在在线 | 51成人网| 亚洲成av人影片在线观看 | 亚洲不卡在线播放 | 久久永久免费 | 天天在线天天在线天天影视 | 亚洲欧洲国产精品你懂的 | 野外啪啪抽搐一进一出 | 亚洲艹|