当前位置:首页 > 电路图基础 > 正文

一个超级实用的单片机调试组件

来源:网络  发布者:电工基础  发布时间:2026-03-08 08:59
DWT跟踪组件 跟踪组件:数据观察点与跟踪(DWT) DWT 中有剩余的计数器,它们典型地用于程序代码的“性能速写”(profiling)。通过编程它们,就可以让它们在计数器溢出时发出事件(以跟踪数据包的形式)。

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

先使能DWT外设,这个由另外内核调试寄存器DEMCR的位24控制,写1使能

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

使能CYCCNT寄存器,这个由DWT的CYCCNTENA 控制,也就是DWT控制寄存器的位0控制,写1使能

寄存器定义:

//0xE000EDFCDEMCRRWDebugExceptionandMonitorControlRegister.
//使能DWT模块的功能位
#defineDEMCR(*(unsignedint*)0xE000EDFC)
#defineTRCENA(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) //显示或设置处理器的周期计数值  

用法示例:

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<< 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);
 
}

审核编辑:汤梓红

相关热词:

相关内容
月度热门TAG关键词
线形2n39062n3904三极管替换差动放大器2sc1815c2073bu406万用测试表倒置状态三极管开关电路三极管振荡电路三极管8050光电三极管3dd15dtip41c开关三极管贴片三极管高频三极管高频管TO-220光电晶体管放大器件BC547微波三极管NPN型三极管恒流源漏极电流NPN三极管S8050
最新文章
三极管用饱和Rce,而MOSFET用饱和Vds?三极管用饱和Rce,而MOSFET用饱和Vds?

时间:2026-03-08

这两种PNP与NPN三极管使用方法你知道吗?这两种PNP与NPN三极管使用方法你知道吗?

时间:2026-03-08

一文了解三极管的开关作用一文了解三极管的开关作用

时间:2026-03-08

关于短路保护的三极管详解关于短路保护的三极管详解

时间:2026-03-08

一文详解变压器的连接方法和联结组别一文详解变压器的连接方法和联结组别

时间:2026-03-08

基于逻辑门的构成解释如何完成任意逻辑的管级电路设计基于逻辑门的构成解释如何完成任意逻辑的管...

时间:2026-03-08

有源钳位技术解析有源钳位技术解析

时间:2026-03-08

从0学电路,万用表演示测量三极管方法从0学电路,万用表演示测量三极管方法

时间:2026-03-08

NE555的有趣电路设计分享NE555的有趣电路设计分享

时间:2026-03-08

电路系统常用的图形符号电路系统常用的图形符号

时间:2026-03-08

热门文章
彩灯电路彩灯电路

时间:2026-03-05

电动机单线远程正反转控制电路图电动机单线远程正反转控制电路图

时间:2026-03-04

三相异步电动机的拆装详讲三相异步电动机的拆装详讲

时间:2026-03-04

三相异步电动机原理三相异步电动机原理

时间:2026-03-04

三相异步电动机的七种调速方式三相异步电动机的七种调速方式

时间:2026-03-04

USB转232电路图USB转232电路图

时间:2026-03-04

转角测量电路转角测量电路

时间:2026-03-05

电风扇红外遥控器2电风扇红外遥控器2

时间:2026-03-04

经典的正弦波发生电路经典的正弦波发生电路

时间:2026-03-05

电度表的工作原理电度表的工作原理

时间:2026-03-04