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

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

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

DWT跟蹤組件調(diào)試

科技綠洲 ? 來(lái)源:一起學(xué)嵌入式 ? 作者:一起學(xué)嵌入式 ? 2023-06-22 14:24 ? 次閱讀

DWT跟蹤組件

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

圖片

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

最典型地,就是使用 CYCCNT寄存器來(lái)測(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)試及跟蹤。

圖片

它有一個(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)啦,要考試?。。EMCR的地址是0xE000 EDFC

圖片圖片

關(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了。

圖片

關(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

圖片

綜上所述

想要使用DWT的CYCCNT步驟:

  1. 先使能DWT外設(shè),這個(gè)由另外內(nèi)核調(diào)試寄存器 DEMCR 的位24控制,寫1使能
  2. 使能CYCCNT寄存器之前,先清 0。
  3. 使能CYCCNT寄存器,這個(gè)由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計(jì)數(shù)器開始計(jì)數(shù)
#define DWT_CTRL        ( *(unsigned int *)0xE0001000 )  
#define CYCCNTENA       ( 0x01 < < 0 ) // DWT的SYCCNT使能位
 
//0xE0001004 DWT_CYCCNT RW Cycle Count register,   
//CYCCNT計(jì)數(shù)器的內(nèi)部值(32位無(wú)符號(hào))
#define DWT_CYCCNT      ( *(unsigned int *)0xE0001004) //顯示或設(shè)置處理器的周期計(jì)數(shù)值

用法示例:

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)
 
/* 初始化時(shí)間戳 */
 
void CPU_TS_TmrInit(void)
{
        /* 使能DWT外設(shè) */
        DEM_CR |= (uint32_t)DEM_CR_TRCENA;               
 
        /* DWT CYCCNT寄存器計(jì)數(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);
}
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5294

    瀏覽量

    119816
  • cpu
    cpu
    +關(guān)注

    關(guān)注

    68

    文章

    10804

    瀏覽量

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

    關(guān)注

    0

    文章

    20

    瀏覽量

    11120
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    詳解DWT跟蹤組件的單片機(jī)調(diào)試技巧

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

    DWT跟蹤組件使用方法

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

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

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

    DWT的相關(guān)資料下載

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

    在STM32F10x中支持哪幾種調(diào)試接口呢

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

    AT32使用內(nèi)核DWT寄存器設(shè)定延時(shí)時(shí)間

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

    如何使用或啟用STM32CubeIDE DWT?

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

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

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

    使用RealView MDK進(jìn)行SW調(diào)試和實(shí)時(shí)跟蹤

    使用RealView MDK進(jìn)行SW調(diào)試和實(shí)時(shí)跟蹤 STM32有兩個(gè)調(diào)試端口,即JTAG和SW。Keil 的ULINK2 USB
    發(fā)表于 08-02 09:27 ?4396次閱讀
    使用RealView MDK進(jìn)行SW<b class='flag-5'>調(diào)試</b>和實(shí)時(shí)<b class='flag-5'>跟蹤</b>

    關(guān)于CoreSight中調(diào)試跟蹤的相關(guān)內(nèi)容

    如今眾多Cortex-M處理器能這么方便調(diào)試,在于有一項(xiàng)基于Arm Cortex-M處理器設(shè)備的CoreSight技術(shù),該技術(shù)引入了強(qiáng)大的新調(diào)試(Debug)和跟蹤(Trace)功能。 下面就來(lái)重點(diǎn)
    的頭像 發(fā)表于 11-03 16:10 ?2020次閱讀

    STM32“隱藏的定時(shí)器”-DWT

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

    詳解CoreSight技術(shù)中的調(diào)試跟蹤功能

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

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

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

    RISC-V調(diào)試和完善的跟蹤解決方案

    RISC-V調(diào)試和完善的跟蹤解決方案ppt分享
    發(fā)表于 07-14 17:15 ?0次下載

    揭秘單片機(jī)調(diào)試利器值之DWT跟蹤組件

    DWT 中有剩余的計(jì)數(shù)器,它們典型地用于程序代碼的“性能速寫”(profiling)。通過(guò)編程它們,就可以讓它們?cè)谟?jì)數(shù)器溢出時(shí)發(fā)出事件(以跟蹤數(shù)據(jù)包的形式)。
    發(fā)表于 02-28 13:55 ?668次閱讀
    揭秘單片機(jī)<b class='flag-5'>調(diào)試</b>利器值之<b class='flag-5'>DWT</b><b class='flag-5'>跟蹤</b><b class='flag-5'>組件</b>